home *** CD-ROM | disk | FTP | other *** search
Emacs Compiled Lisp | 1995-08-29 | 15.8 KB |
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was processed as: Emacs Compiled Lisp
(other/emacsCompiledLisp).
This format is not currently supported by dexvert.
Confidence | Program | Detection | Match Type | Support
|
---|
1%
| dexvert
| Emacs Compiled Lisp (other/emacsCompiledLisp)
| magic
| Unsupported |
1%
| dexvert
| Combustion 2 Particle Library (other/combustion2ParticleLibrary)
| ext
| Unsupported |
100%
| file
| Emacs/XEmacs v19 byte-compiled Lisp data
| default
| |
99%
| file
| data
| default
| |
100%
| TrID
| Emacs/XEmacs byte-compiled Lisp (generic)
| default
| |
100%
| xdgMime
| text/x-emacs-lisp
| default (weak)
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 3b 45 4c 43 13 00 00 00 | 0a 3b 3b 3b 20 63 6f 6d |;ELC....|.;;; com|
|00000010| 70 69 6c 65 64 20 62 79 | 20 63 74 68 6f 6d 70 40 |piled by| cthomp@|
|00000020| 77 69 6c 6c 6f 77 2e 63 | 73 2e 75 69 75 63 2e 65 |willow.c|s.uiuc.e|
|00000030| 64 75 20 6f 6e 20 54 75 | 65 20 41 75 67 20 32 39 |du on Tu|e Aug 29|
|00000040| 20 31 33 3a 35 37 3a 30 | 32 20 31 39 39 35 0a 3b | 13:57:0|2 1995.;|
|00000050| 3b 3b 20 66 72 6f 6d 20 | 66 69 6c 65 20 2f 78 65 |;; from |file /xe|
|00000060| 6d 61 63 73 2f 78 65 6d | 61 63 73 2d 31 39 2e 31 |macs/xem|acs-19.1|
|00000070| 33 2d 72 65 6c 65 61 73 | 65 2f 65 64 69 74 6f 72 |3-releas|e/editor|
|00000080| 2f 6c 69 73 70 2f 65 64 | 65 62 75 67 2f 63 6c 2d |/lisp/ed|ebug/cl-|
|00000090| 72 65 61 64 2e 65 6c 0a | 3b 3b 3b 20 65 6d 61 63 |read.el.|;;; emac|
|000000a0| 73 20 76 65 72 73 69 6f | 6e 20 31 39 2e 31 33 20 |s versio|n 19.13 |
|000000b0| 58 45 6d 61 63 73 20 4c | 75 63 69 64 2e 0a 3b 3b |XEmacs L|ucid..;;|
|000000c0| 3b 20 62 79 74 65 63 6f | 6d 70 20 76 65 72 73 69 |; byteco|mp versi|
|000000d0| 6f 6e 20 32 2e 32 35 3b | 20 31 2d 53 65 70 2d 39 |on 2.25;| 1-Sep-9|
|000000e0| 34 2e 0a 3b 3b 3b 20 6f | 70 74 69 6d 69 7a 61 74 |4..;;; o|ptimizat|
|000000f0| 69 6f 6e 20 69 73 20 6f | 6e 2e 0a 3b 3b 3b 20 74 |ion is o|n..;;; t|
|00000100| 68 69 73 20 66 69 6c 65 | 20 75 73 65 73 20 6f 70 |his file| uses op|
|00000110| 63 6f 64 65 73 20 77 68 | 69 63 68 20 64 6f 20 6e |codes wh|ich do n|
|00000120| 6f 74 20 65 78 69 73 74 | 20 69 6e 20 45 6d 61 63 |ot exist| in Emac|
|00000130| 73 20 31 38 2e 0a 0a 28 | 69 66 20 28 61 6e 64 20 |s 18...(|if (and |
|00000140| 28 62 6f 75 6e 64 70 20 | 27 65 6d 61 63 73 2d 76 |(boundp |'emacs-v|
|00000150| 65 72 73 69 6f 6e 29 0a | 09 20 28 6f 72 20 28 61 |ersion).|. (or (a|
|00000160| 6e 64 20 28 62 6f 75 6e | 64 70 20 27 65 70 6f 63 |nd (boun|dp 'epoc|
|00000170| 68 3a 3a 76 65 72 73 69 | 6f 6e 29 20 65 70 6f 63 |h::versi|on) epoc|
|00000180| 68 3a 3a 76 65 72 73 69 | 6f 6e 29 0a 09 20 20 20 |h::versi|on).. |
|00000190| 20 20 28 73 74 72 69 6e | 67 2d 6c 65 73 73 70 20 | (strin|g-lessp |
|000001a0| 65 6d 61 63 73 2d 76 65 | 72 73 69 6f 6e 20 22 31 |emacs-ve|rsion "1|
|000001b0| 39 22 29 29 29 0a 20 20 | 20 20 28 65 72 72 6f 72 |9"))). | (error|
|000001c0| 20 22 54 68 69 73 20 66 | 69 6c 65 20 77 61 73 20 | "This f|ile was |
|000001d0| 63 6f 6d 70 69 6c 65 64 | 20 66 6f 72 20 45 6d 61 |compiled| for Ema|
|000001e0| 63 73 20 31 39 2e 22 29 | 29 0a 0a 28 62 79 74 65 |cs 19.")|)..(byte|
|000001f0| 2d 63 6f 64 65 20 22 c0 | c1 21 88 c2 c3 21 88 c4 |-code ".|.!...!..|
|00000200| c5 c6 5c 22 87 22 20 5b | 72 65 71 75 69 72 65 20 |..\"." [|require |
|00000210| 63 6c 20 70 72 6f 76 69 | 64 65 20 63 6c 2d 72 65 |cl provi|de cl-re|
|00000220| 61 64 20 61 75 74 6f 6c | 6f 61 64 20 63 6f 6d 70 |ad autol|oad comp|
|00000230| 69 6c 65 64 2d 66 75 6e | 63 74 69 6f 6e 2d 70 20 |iled-fun|ction-p |
|00000240| 22 62 79 74 65 63 6f 6d | 70 22 5d 20 33 29 0a 28 |"bytecom|p"] 3).(|
|00000250| 64 65 66 76 61 72 20 63 | 6c 2d 72 65 61 64 2d 61 |defvar c|l-read-a|
|00000260| 63 74 69 76 65 20 6e 69 | 6c 20 22 5c 0a 42 75 66 |ctive ni|l "\.Buf|
|00000270| 66 65 72 20 6c 6f 63 61 | 6c 20 76 61 72 69 61 62 |fer loca|l variab|
|00000280| 6c 65 20 74 68 61 74 20 | 65 6e 61 62 6c 65 73 20 |le that |enables |
|00000290| 43 6f 6d 6d 6f 6e 20 4c | 69 73 70 20 73 74 79 6c |Common L|isp styl|
|000002a0| 65 20 73 79 6e 74 61 78 | 20 72 65 61 64 69 6e 67 |e syntax| reading|
|000002b0| 2e 22 29 0a 28 62 79 74 | 65 2d 63 6f 64 65 20 22 |.").(byt|e-code "|
|000002c0| c0 c1 21 88 c2 c1 c3 5c | 22 88 c1 0c 9e ac 84 c5 |..!....\|".......|
|000002d0| 0c 42 14 c3 87 22 20 5b | 6d 61 6b 65 2d 76 61 72 |.B..." [|make-var|
|000002e0| 69 61 62 6c 65 2d 62 75 | 66 66 65 72 2d 6c 6f 63 |iable-bu|ffer-loc|
|000002f0| 61 6c 20 63 6c 2d 72 65 | 61 64 2d 61 63 74 69 76 |al cl-re|ad-activ|
|00000300| 65 20 73 65 74 2d 64 65 | 66 61 75 6c 74 20 6e 69 |e set-de|fault ni|
|00000310| 6c 20 6d 69 6e 6f 72 2d | 6d 6f 64 65 2d 61 6c 69 |l minor-|mode-ali|
|00000320| 73 74 20 28 63 6c 2d 72 | 65 61 64 2d 61 63 74 69 |st (cl-r|ead-acti|
|00000330| 76 65 20 22 20 43 4c 22 | 29 5d 20 33 29 0a 28 64 |ve " CL"|)] 3).(d|
|00000340| 65 66 76 61 72 20 72 65 | 61 64 65 72 3a 72 65 61 |efvar re|ader:rea|
|00000350| 64 74 61 62 6c 65 2d 73 | 69 7a 65 20 32 35 36 20 |dtable-s|ize 256 |
|00000360| 22 5c 0a 54 68 65 20 73 | 69 7a 65 20 6f 66 20 61 |"\.The s|ize of a|
|00000370| 20 72 65 61 64 74 61 62 | 6c 65 2e 22 29 0a 28 66 | readtab|le.").(f|
|00000380| 73 65 74 20 27 63 6f 70 | 79 2d 72 65 61 64 74 61 |set 'cop|y-readta|
|00000390| 62 6c 65 20 23 5b 28 26 | 72 65 73 74 20 2d 2d 72 |ble #[(&|rest --r|
|000003a0| 65 73 74 2d 2d 38 35 35 | 30 30 29 20 22 08 ab 87 |est--855|00) "...|
|000003b0| 08 89 41 10 40 aa 81 09 | 1a 08 ab 87 08 89 41 10 |..A.@...|......A.|
|000003c0| 40 aa 85 c3 0c 54 c5 5c | 22 1e 06 08 ab 8a c7 c8 |@....T.\|".......|
|000003d0| c9 08 47 ca 5c 5c 44 5c | 22 88 5c 6e ac 83 0e 0b |..G.\\D\|".\n....|
|000003e0| 12 cc 1e 0d 0c 1e 0e cf | 1e 10 0e 0d 0e 0e 58 ab |........|......X.|
|000003f0| a3 5c 6e 0e 0d 48 16 10 | 0e 06 0e 0d d1 0e 10 21 |.\n..H..|.......!|
|00000400| ab 86 d2 0e 10 21 aa 82 | 0e 10 49 88 0e 0d d3 5c |.....!..|..I....\|
|00000410| 5c 89 16 0d aa 58 0e 06 | 2d 87 22 20 5b 2d 2d 72 |\....X..|-." [--r|
|00000420| 65 73 74 2d 2d 38 35 35 | 30 30 20 2a 72 65 61 64 |est--855|00 *read|
|00000430| 74 61 62 6c 65 2a 20 66 | 72 6f 6d 2d 72 65 61 64 |table* f|rom-read|
|00000440| 74 61 62 6c 65 20 6d 61 | 6b 65 2d 76 65 63 74 6f |table ma|ke-vecto|
|00000450| 72 20 72 65 61 64 65 72 | 3a 72 65 61 64 74 61 62 |r reader|:readtab|
|00000460| 6c 65 2d 73 69 7a 65 20 | 69 6c 6c 65 67 61 6c 20 |le-size |illegal |
|00000470| 74 6f 2d 72 65 61 64 74 | 61 62 6c 65 20 73 69 67 |to-readt|able sig|
|00000480| 6e 61 6c 20 77 72 6f 6e | 67 2d 6e 75 6d 62 65 72 |nal wron|g-number|
|00000490| 2d 6f 66 2d 61 72 67 75 | 6d 65 6e 74 73 20 63 6f |-of-argu|ments co|
|000004a0| 70 79 2d 72 65 61 64 74 | 61 62 6c 65 20 32 20 72 |py-readt|able 2 r|
|000004b0| 65 61 64 65 72 3a 69 6e | 74 65 72 6e 61 6c 2d 73 |eader:in|ternal-s|
|000004c0| 74 61 6e 64 61 72 64 2d | 72 65 61 64 74 61 62 6c |tandard-|readtabl|
|000004d0| 65 20 30 20 69 20 47 38 | 35 35 30 31 20 6e 69 6c |e 0 i G8|5501 nil|
|000004e0| 20 66 72 6f 6d 2d 73 79 | 6e 74 61 78 20 76 65 63 | from-sy|ntax vec|
|000004f0| 74 6f 72 70 20 63 6f 70 | 79 2d 73 65 71 75 65 6e |torp cop|y-sequen|
|00000500| 63 65 20 31 5d 20 35 20 | 22 5c 0a 52 65 74 75 72 |ce 1] 5 |"\.Retur|
|00000510| 6e 20 61 20 63 6f 70 79 | 20 6f 66 20 46 52 4f 4d |n a copy| of FROM|
|00000520| 2d 52 45 41 44 54 41 42 | 4c 45 20 28 64 65 66 61 |-READTAB|LE (defa|
|00000530| 75 6c 74 3a 20 2a 72 65 | 61 64 74 61 62 6c 65 2a |ult: *re|adtable*|
|00000540| 29 2e 20 49 66 20 74 68 | 65 0a 46 52 4f 4d 2d 52 |). If th|e.FROM-R|
|00000550| 45 41 44 54 41 42 4c 45 | 20 61 72 67 75 6d 65 6e |EADTABLE| argumen|
|00000560| 74 20 69 73 20 70 72 6f | 76 69 64 65 64 20 61 73 |t is pro|vided as|
|00000570| 20 60 6e 69 6c 27 2c 20 | 6d 61 6b 65 20 61 20 63 | `nil', |make a c|
|00000580| 6f 70 79 20 6f 66 20 61 | 0a 73 74 61 6e 64 61 72 |opy of a|.standar|
|00000590| 64 20 28 43 4c 2d 6c 69 | 6b 65 29 20 72 65 61 64 |d (CL-li|ke) read|
|000005a0| 74 61 62 6c 65 2e 20 49 | 66 20 54 4f 2d 52 45 41 |table. I|f TO-REA|
|000005b0| 44 54 41 42 4c 45 20 69 | 73 20 70 72 6f 76 69 64 |DTABLE i|s provid|
|000005c0| 65 64 2c 20 6d 6f 64 69 | 66 79 20 61 6e 64 0a 72 |ed, modi|fy and.r|
|000005d0| 65 74 75 72 6e 20 69 74 | 2c 20 6f 74 68 65 72 77 |eturn it|, otherw|
|000005e0| 69 73 65 20 63 72 65 61 | 74 65 20 61 20 6e 65 77 |ise crea|te a new|
|000005f0| 20 72 65 61 64 74 61 62 | 6c 65 20 6f 62 6a 65 63 | readtab|le objec|
|00000600| 74 2e 22 5d 29 0a 28 66 | 73 65 74 20 27 72 65 61 |t."]).(f|set 'rea|
|00000610| 64 65 72 3a 67 65 74 2d | 72 65 61 64 74 61 62 6c |der:get-|readtabl|
|00000620| 65 2d 65 6e 74 72 79 20 | 27 28 6d 61 63 72 6f 20 |e-entry |'(macro |
|00000630| 2e 20 23 5b 28 63 68 61 | 72 20 72 65 61 64 74 61 |. #[(cha|r readta|
|00000640| 62 6c 65 29 20 22 c0 09 | 5c 6e 45 87 22 20 5b 61 |ble) "..|\nE." [a|
|00000650| 72 65 66 20 72 65 61 64 | 74 61 62 6c 65 20 63 68 |ref read|table ch|
|00000660| 61 72 5d 20 33 5d 29 29 | 0a 28 66 73 65 74 20 27 |ar] 3]))|.(fset '|
|00000670| 73 65 74 2d 6d 61 63 72 | 6f 2d 63 68 61 72 61 63 |set-macr|o-charac|
|00000680| 74 65 72 20 23 5b 28 63 | 68 61 72 20 66 75 6e 63 |ter #[(c|har func|
|00000690| 74 69 6f 6e 20 26 6f 70 | 74 69 6f 6e 61 6c 20 72 |tion &op|tional r|
|000006a0| 65 61 64 74 61 62 6c 65 | 29 20 22 08 ac 82 09 10 |eadtable|) ".....|
|000006b0| c2 0b 21 ac 85 c4 c5 0b | 5c 22 88 08 0e 06 0b 49 |..!.....|\".....I|
|000006c0| 88 c7 87 22 20 5b 72 65 | 61 64 74 61 62 6c 65 20 |..." [re|adtable |
|000006d0| 2a 72 65 61 64 74 61 62 | 6c 65 2a 20 72 65 61 64 |*readtab|le* read|
|000006e0| 65 72 3a 66 75 6e 63 74 | 69 6f 6e 70 20 66 75 6e |er:funct|ionp fun|
|000006f0| 63 74 69 6f 6e 20 65 72 | 72 6f 72 20 22 4e 6f 74 |ction er|ror "Not|
|00000700| 20 76 61 6c 69 64 20 63 | 68 61 72 61 63 74 65 72 | valid c|haracter|
|00000710| 20 6d 61 63 72 6f 20 66 | 75 6e 63 74 69 6f 6e 3a | macro f|unction:|
|00000720| 20 25 73 22 20 63 68 61 | 72 20 74 5d 20 33 20 22 | %s" cha|r t] 3 "|
|00000730| 5c 0a 4d 61 6b 65 73 20 | 43 48 41 52 20 74 6f 20 |\.Makes |CHAR to |
|00000740| 62 65 20 61 20 6d 61 63 | 72 6f 20 63 68 61 72 61 |be a mac|ro chara|
|00000750| 63 74 65 72 20 77 69 74 | 68 20 46 55 4e 43 54 49 |cter wit|h FUNCTI|
|00000760| 4f 4e 20 61 73 20 68 61 | 6e 64 6c 65 72 2e 0a 57 |ON as ha|ndler..W|
|00000770| 68 65 6e 20 43 48 41 52 | 20 69 73 20 73 65 65 6e |hen CHAR| is seen|
|00000780| 20 62 79 20 72 65 61 64 | 65 72 3a 72 65 61 64 2d | by read|er:read-|
|00000790| 66 72 6f 6d 2d 62 75 66 | 66 65 72 2c 20 69 74 20 |from-buf|fer, it |
|000007a0| 63 61 6c 6c 73 20 46 55 | 4e 43 54 49 4f 4e 2e 0a |calls FU|NCTION..|
|000007b0| 52 65 74 75 72 6e 73 20 | 61 6c 77 61 79 73 20 74 |Returns |always t|
|000007c0| 2e 20 4f 70 74 69 6f 6e | 61 6c 20 61 72 67 75 6d |. Option|al argum|
|000007d0| 65 6e 74 20 52 45 41 44 | 54 41 42 4c 45 20 69 73 |ent READ|TABLE is|
|000007e0| 20 74 68 65 20 72 65 61 | 64 74 61 62 6c 65 20 74 | the rea|dtable t|
|000007f0| 6f 20 73 65 74 0a 74 68 | 65 20 6d 61 63 72 6f 20 |o set.th|e macro |
|00000800| 63 68 61 72 61 63 74 65 | 72 20 69 6e 20 28 64 65 |characte|r in (de|
|00000810| 66 61 75 6c 74 3a 20 2a | 72 65 61 64 74 61 62 6c |fault: *|readtabl|
|00000820| 65 2a 29 2e 22 5d 29 0a | 28 62 79 74 65 2d 63 6f |e*)."]).|(byte-co|
|00000830| 64 65 20 22 c0 c1 c2 c3 | 23 88 c0 c1 c4 c5 23 87 |de "....|#.....#.|
|00000840| 22 20 5b 70 75 74 20 73 | 65 74 2d 6d 61 63 72 6f |" [put s|et-macro|
|00000850| 2d 63 68 61 72 61 63 74 | 65 72 20 65 64 65 62 75 |-charact|er edebu|
|00000860| 67 2d 66 6f 72 6d 2d 73 | 70 65 63 20 28 26 64 65 |g-form-s|pec (&de|
|00000870| 66 69 6e 65 20 73 65 78 | 70 20 66 75 6e 63 74 69 |fine sex|p functi|
|00000880| 6f 6e 2d 66 6f 72 6d 20 | 26 6f 70 74 69 6f 6e 61 |on-form |&optiona|
|00000890| 6c 20 73 65 78 70 29 20 | 6c 69 73 70 2d 69 6e 64 |l sexp) |lisp-ind|
|000008a0| 65 6e 74 2d 66 75 6e 63 | 74 69 6f 6e 20 31 5d 20 |ent-func|tion 1] |
|000008b0| 34 29 0a 28 66 73 65 74 | 20 27 67 65 74 2d 6d 61 |4).(fset| 'get-ma|
|000008c0| 63 72 6f 2d 63 68 61 72 | 61 63 74 65 72 20 23 5b |cro-char|acter #[|
|000008d0| 28 63 68 61 72 20 26 6f | 70 74 69 6f 6e 61 6c 20 |(char &o|ptional |
|000008e0| 72 65 61 64 74 61 62 6c | 65 29 20 22 08 ac 82 09 |readtabl|e) "....|
|000008f0| 10 08 5c 6e 48 1b c4 0b | 21 ad 81 0b 29 87 22 20 |..\nH...|!...)." |
|00000900| 5b 72 65 61 64 74 61 62 | 6c 65 20 2a 72 65 61 64 |[readtab|le *read|
|00000910| 74 61 62 6c 65 2a 20 63 | 68 61 72 20 65 6e 74 72 |table* c|har entr|
|00000920| 79 20 72 65 61 64 65 72 | 3a 66 75 6e 63 74 69 6f |y reader|:functio|
|00000930| 6e 70 5d 20 32 20 22 5c | 0a 52 65 74 75 72 6e 20 |np] 2 "\|.Return |
|00000940| 74 68 65 20 66 75 6e 63 | 74 69 6f 6e 20 61 73 73 |the func|tion ass|
|00000950| 6f 63 69 61 74 65 64 20 | 77 69 74 68 20 74 68 65 |ociated |with the|
|00000960| 20 63 68 61 72 61 63 74 | 65 72 20 43 48 41 52 20 | charact|er CHAR |
|00000970| 69 6e 20 52 45 41 44 54 | 41 42 4c 45 0a 28 64 65 |in READT|ABLE.(de|
|00000980| 66 61 75 6c 74 3a 20 2a | 72 65 61 64 74 61 62 6c |fault: *|readtabl|
|00000990| 65 2a 2e 29 2e 20 49 66 | 20 63 68 61 72 20 69 73 |e*.). If| char is|
|000009a0| 6e 27 74 20 61 20 6d 61 | 63 72 6f 20 63 68 61 72 |n't a ma|cro char|
|000009b0| 61 74 65 72 20 69 6e 0a | 52 45 41 44 54 41 42 4c |ater in.|READTABL|
|000009c0| 45 2c 20 72 65 74 75 72 | 6e 20 6e 69 6c 2e 22 5d |E, retur|n nil."]|
|000009d0| 29 0a 28 66 73 65 74 20 | 27 73 65 74 2d 73 79 6e |).(fset |'set-syn|
|000009e0| 74 61 78 2d 66 72 6f 6d | 2d 63 68 61 72 61 63 74 |tax-from|-charact|
|000009f0| 65 72 20 23 5b 28 74 6f | 2d 63 68 61 72 20 66 72 |er #[(to|-char fr|
|00000a00| 6f 6d 2d 63 68 61 72 20 | 26 6f 70 74 69 6f 6e 61 |om-char |&optiona|
|00000a10| 6c 20 74 6f 2d 72 65 61 | 64 74 61 62 6c 65 20 66 |l to-rea|dtable f|
|00000a20| 72 6f 6d 2d 72 65 61 64 | 74 61 62 6c 65 29 20 22 |rom-read|table) "|
|00000a30| 08 ac 82 09 10 5c 6e ac | 82 0b 12 5c 6e 0c 48 1d |.....\n.|...\n.H.|
|00000a40| c6 0d 21 ab 84 c7 0d 21 | 15 08 0e 08 0d 49 88 29 |..!....!|.....I.)|
|00000a50| c9 87 22 20 5b 74 6f 2d | 72 65 61 64 74 61 62 6c |.." [to-|readtabl|
|00000a60| 65 20 2a 72 65 61 64 74 | 61 62 6c 65 2a 20 66 72 |e *readt|able* fr|
|00000a70| 6f 6d 2d 72 65 61 64 74 | 61 62 6c 65 20 72 65 61 |om-readt|able rea|
|00000a80| 64 65 72 3a 69 6e 74 65 | 72 6e 61 6c 2d 73 74 61 |der:inte|rnal-sta|
|00000a90| 6e 64 61 72 64 2d 72 65 | 61 64 74 61 62 6c 65 20 |ndard-re|adtable |
|00000aa0| 66 72 6f 6d 2d 63 68 61 | 72 20 66 72 6f 6d 2d 73 |from-cha|r from-s|
|00000ab0| 79 6e 74 61 78 20 76 65 | 63 74 6f 72 70 20 63 6f |yntax ve|ctorp co|
|00000ac0| 70 79 2d 73 65 71 75 65 | 6e 63 65 20 74 6f 2d 63 |py-seque|nce to-c|
|00000ad0| 68 61 72 20 74 5d 20 33 | 20 22 5c 0a 4d 61 6b 65 |har t] 3| "\.Make|
|00000ae0| 20 74 68 65 20 73 79 6e | 74 61 78 20 6f 66 20 54 | the syn|tax of T|
|00000af0| 4f 2d 43 48 41 52 20 62 | 65 20 74 68 65 20 73 61 |O-CHAR b|e the sa|
|00000b00| 6d 65 20 61 73 20 74 68 | 65 20 73 79 6e 74 61 78 |me as th|e syntax|
|00000b10| 20 6f 66 20 46 52 4f 4d | 2d 43 48 41 52 2e 0a 4f | of FROM|-CHAR..O|
|00000b20| 70 74 69 6f 6e 61 6c 20 | 54 4f 2d 52 45 41 44 54 |ptional |TO-READT|
|00000b30| 41 42 4c 45 20 61 6e 64 | 20 46 52 4f 4d 2d 52 45 |ABLE and| FROM-RE|
|00000b40| 41 44 54 41 42 4c 45 20 | 61 72 65 20 74 68 65 20 |ADTABLE |are the |
|00000b50| 63 6f 72 72 65 73 70 6f | 6e 64 69 6e 67 20 74 61 |correspo|nding ta|
|00000b60| 62 6c 65 73 0a 74 6f 20 | 75 73 65 2e 20 54 4f 2d |bles.to |use. TO-|
|00000b70| 52 45 41 44 54 41 42 4c | 45 20 64 65 66 61 75 6c |READTABL|E defaul|
|00000b80| 74 73 20 74 6f 20 74 68 | 65 20 63 75 72 72 65 6e |ts to th|e curren|
|00000b90| 74 20 72 65 61 64 74 61 | 62 6c 65 0a 28 2a 72 65 |t readta|ble.(*re|
|00000ba0| 61 64 74 61 62 6c 65 2a | 29 2c 20 61 6e 64 20 46 |adtable*|), and F|
|00000bb0| 52 4f 4d 2d 52 45 41 44 | 54 41 42 4c 45 20 74 6f |ROM-READ|TABLE to|
|00000bc0| 20 6e 69 6c 2c 20 6d 65 | 61 6e 69 6e 67 20 74 6f | nil, me|aning to|
|00000bd0| 20 75 73 65 20 74 68 65 | 0a 73 79 6e 74 61 78 65 | use the|.syntaxe|
|00000be0| 73 20 66 72 6f 6d 20 74 | 68 65 20 73 74 61 6e 64 |s from t|he stand|
|00000bf0| 61 72 64 20 4c 69 73 70 | 20 52 65 61 64 74 61 62 |ard Lisp| Readtab|
|00000c00| 6c 65 2e 22 5d 29 0a 28 | 66 73 65 74 20 27 6d 61 |le."]).(|fset 'ma|
|00000c10| 6b 65 2d 64 69 73 70 61 | 74 63 68 2d 6d 61 63 72 |ke-dispa|tch-macr|
|00000c20| 6f 2d 63 68 61 72 61 63 | 74 65 72 20 23 5b 28 63 |o-charac|ter #[(c|
|00000c30| 68 61 72 20 26 6f 70 74 | 69 6f 6e 61 6c 20 72 65 |har &opt|ional re|
|00000c40| 61 64 74 61 62 6c 65 29 | 20 22 08 ac 82 09 10 08 |adtable)| "......|
|00000c50| 5c 6e c3 0c c5 5c 22 49 | 87 22 20 5b 72 65 61 64 |\n...\"I|." [read|
|00000c60| 74 61 62 6c 65 20 2a 72 | 65 61 64 74 61 62 6c 65 |table *r|eadtable|
|00000c70| 2a 20 63 68 61 72 20 6d | 61 6b 65 2d 76 65 63 74 |* char m|ake-vect|
|00000c80| 6f 72 20 72 65 61 64 65 | 72 3a 72 65 61 64 74 61 |or reade|r:readta|
|00000c90| 62 6c 65 2d 73 69 7a 65 | 20 6e 69 6c 5d 20 35 20 |ble-size| nil] 5 |
|00000ca0| 22 5c 0a 4c 65 74 20 43 | 48 41 52 20 62 65 20 61 |"\.Let C|HAR be a|
|00000cb0| 20 64 69 73 70 61 74 63 | 68 20 6d 61 63 72 6f 20 | dispatc|h macro |
|00000cc0| 63 68 61 72 61 63 74 65 | 72 20 69 6e 20 52 45 41 |characte|r in REA|
|00000cd0| 44 54 41 42 4c 45 20 28 | 64 65 66 61 75 6c 74 3a |DTABLE (|default:|
|00000ce0| 20 2a 72 65 61 64 74 61 | 62 6c 65 2a 29 2e 22 5d | *readta|ble*)."]|
|00000cf0| 29 0a 28 66 73 65 74 20 | 27 73 65 74 2d 64 69 73 |).(fset |'set-dis|
|00000d00| 70 61 74 63 68 2d 6d 61 | 63 72 6f 2d 63 68 61 72 |patch-ma|cro-char|
|00000d10| 61 63 74 65 72 20 23 5b | 28 64 69 73 70 2d 63 68 |acter #[|(disp-ch|
|00000d20| 61 72 20 73 75 62 2d 63 | 68 61 72 20 66 75 6e 63 |ar sub-c|har func|
|00000d30| 74 69 6f 6e 20 26 6f 70 | 74 69 6f 6e 61 6c 20 72 |tion &op|tional r|
|00000d40| 65 61 64 74 61 62 6c 65 | 29 20 22 08 ac 82 09 10 |eadtable|) ".....|
|00000d50| 08 5c 6e 48 1b c4 0b 21 | ac 85 c5 c6 5c 6e 5c 22 |.\nH...!|....\n\"|
|00000d60| 88 c7 0e 08 21 ac 86 c5 | c9 0e 08 5c 22 88 0b 0e |....!...|...\"...|
|00000d70| 5c 6e 0e 08 49 29 87 22 | 20 5b 72 65 61 64 74 61 |\n..I)."| [readta|
|00000d80| 62 6c 65 20 2a 72 65 61 | 64 74 61 62 6c 65 2a 20 |ble *rea|dtable* |
|00000d90| 64 69 73 70 2d 63 68 61 | 72 20 64 69 73 70 2d 74 |disp-cha|r disp-t|
|00000da0| 61 62 6c 65 20 76 65 63 | 74 6f 72 70 20 65 72 72 |able vec|torp err|
|00000db0| 6f 72 20 22 60 25 63 27 | 20 6e 6f 74 20 61 20 64 |or "`%c'| not a d|
|00000dc0| 69 73 70 61 74 63 68 20 | 6d 61 63 72 6f 20 63 68 |ispatch |macro ch|
|00000dd0| 61 72 61 63 74 65 72 2e | 22 20 72 65 61 64 65 72 |aracter.|" reader|
|00000de0| 3a 66 75 6e 63 74 69 6f | 6e 70 20 66 75 6e 63 74 |:functio|np funct|
|00000df0| 69 6f 6e 20 22 4e 6f 74 | 20 76 61 6c 69 64 20 64 |ion "Not| valid d|
|00000e00| 69 73 70 61 74 63 68 20 | 63 68 61 72 61 63 74 65 |ispatch |characte|
|00000e10| 72 20 6d 61 63 72 6f 20 | 66 75 6e 63 74 69 6f 6e |r macro |function|
|00000e20| 3a 20 25 73 22 20 73 75 | 62 2d 63 68 61 72 5d 20 |: %s" su|b-char] |
|00000e30| 33 20 22 5c 0a 4d 61 6b | 65 20 72 65 61 64 69 6e |3 "\.Mak|e readin|
|00000e40| 67 20 43 48 41 52 31 20 | 66 6f 6c 6c 6f 77 65 64 |g CHAR1 |followed|
|00000e50| 20 62 79 20 43 48 41 52 | 32 20 62 65 20 68 61 6e | by CHAR|2 be han|
|00000e60| 64 6c 65 64 20 62 79 20 | 46 55 4e 43 54 49 4f 4e |dled by |FUNCTION|
|00000e70| 2e 0a 4f 70 74 69 6f 6e | 61 6c 20 61 72 67 75 6d |..Option|al argum|
|00000e80| 65 6e 74 20 52 45 41 44 | 54 41 42 4c 45 20 28 64 |ent READ|TABLE (d|
|00000e90| 65 66 61 75 6c 74 3a 20 | 2a 72 65 61 64 74 61 62 |efault: |*readtab|
|00000ea0| 6c 65 2a 29 2e 20 20 43 | 48 41 52 31 20 6d 75 73 |le*). C|HAR1 mus|
|00000eb0| 74 20 66 69 72 73 74 20 | 62 65 20 0a 6d 61 64 65 |t first |be .made|
|00000ec0| 20 61 20 64 69 73 70 61 | 74 63 68 20 63 68 61 72 | a dispa|tch char|
|00000ed0| 20 77 69 74 68 20 60 6d | 61 6b 65 2d 64 69 73 70 | with `m|ake-disp|
|00000ee0| 61 74 63 68 2d 6d 61 63 | 72 6f 2d 63 68 61 72 61 |atch-mac|ro-chara|
|00000ef0| 63 74 65 72 27 2e 22 5d | 29 0a 28 62 79 74 65 2d |cter'."]|).(byte-|
|00000f00| 63 6f 64 65 20 22 c0 c1 | c2 c3 23 88 c0 c1 c4 c5 |code "..|..#.....|
|00000f10| 23 87 22 20 5b 70 75 74 | 20 73 65 74 2d 64 69 73 |#." [put| set-dis|
|00000f20| 70 61 74 63 68 2d 6d 61 | 63 72 6f 2d 63 68 61 72 |patch-ma|cro-char|
|00000f30| 61 63 74 65 72 20 65 64 | 65 62 75 67 2d 66 6f 72 |acter ed|ebug-for|
|00000f40| 6d 2d 73 70 65 63 20 28 | 26 64 65 66 69 6e 65 20 |m-spec (|&define |
|00000f50| 73 65 78 70 20 73 65 78 | 70 20 66 75 6e 63 74 69 |sexp sex|p functi|
|00000f60| 6f 6e 2d 66 6f 72 6d 20 | 26 6f 70 74 69 6f 6e 61 |on-form |&optiona|
|00000f70| 6c 20 64 65 66 2d 66 6f | 72 6d 29 20 6c 69 73 70 |l def-fo|rm) lisp|
|00000f80| 2d 69 6e 64 65 6e 74 2d | 66 75 6e 63 74 69 6f 6e |-indent-|function|
|00000f90| 20 32 5d 20 34 29 0a 28 | 66 73 65 74 20 27 67 65 | 2] 4).(|fset 'ge|
|00000fa0| 74 2d 64 69 73 70 61 74 | 63 68 2d 6d 61 63 72 6f |t-dispat|ch-macro|
|00000fb0| 2d 63 68 61 72 61 63 74 | 65 72 20 23 5b 28 64 69 |-charact|er #[(di|
|00000fc0| 73 70 2d 63 68 61 72 20 | 73 75 62 2d 63 68 61 72 |sp-char |sub-char|
|00000fd0| 20 26 6f 70 74 69 6f 6e | 61 6c 20 72 65 61 64 74 | &option|al readt|
|00000fe0| 61 62 6c 65 29 20 22 08 | ac 82 09 10 08 5c 6e 48 |able) ".|.....\nH|
|00000ff0| 1b c4 0b 21 ad 8c c5 0b | 0e 06 48 21 ad 84 0b 0e |...!....|..H!....|
|00001000| 06 48 29 87 22 20 5b 72 | 65 61 64 74 61 62 6c 65 |.H)." [r|eadtable|
|00001010| 20 2a 72 65 61 64 74 61 | 62 6c 65 2a 20 64 69 73 | *readta|ble* dis|
|00001020| 70 2d 63 68 61 72 20 64 | 69 73 70 2d 74 61 62 6c |p-char d|isp-tabl|
|00001030| 65 20 76 65 63 74 6f 72 | 70 20 72 65 61 64 65 72 |e vector|p reader|
|00001040| 3a 66 75 6e 63 74 69 6f | 6e 70 20 73 75 62 2d 63 |:functio|np sub-c|
|00001050| 68 61 72 5d 20 33 20 22 | 5c 0a 52 65 74 75 72 6e |har] 3 "|\.Return|
|00001060| 20 74 68 65 20 6d 61 63 | 72 6f 20 63 68 61 72 61 | the mac|ro chara|
|00001070| 63 74 65 72 20 66 75 6e | 63 74 69 6f 6e 20 66 6f |cter fun|ction fo|
|00001080| 72 20 53 55 42 2d 43 48 | 41 52 20 75 6e 73 65 72 |r SUB-CH|AR unser|
|00001090| 20 44 49 53 50 2d 43 48 | 41 52 20 69 6e 0a 52 45 | DISP-CH|AR in.RE|
|000010a0| 41 44 54 41 42 4c 45 20 | 28 64 65 66 61 75 6c 74 |ADTABLE |(default|
|000010b0| 3a 20 2a 72 65 61 64 74 | 61 62 6c 65 2a 29 2c 20 |: *readt|able*), |
|000010c0| 6f 72 20 6e 69 6c 20 69 | 66 20 74 68 65 72 65 20 |or nil i|f there |
|000010d0| 69 73 20 6e 6f 20 73 75 | 63 68 0a 66 75 6e 63 74 |is no su|ch.funct|
|000010e0| 69 6f 6e 2e 22 5d 29 0a | 28 66 73 65 74 20 27 72 |ion."]).|(fset 'r|
|000010f0| 65 61 64 65 72 3a 66 75 | 6e 63 74 69 6f 6e 70 20 |eader:fu|nctionp |
|00001100| 23 5b 28 66 75 6e 63 74 | 69 6f 6e 29 20 22 08 39 |#[(funct|ion) ".9|
|00001110| ab 85 c1 08 21 ae 8d c2 | 08 21 ae 88 08 3a ad 84 |....!...|.!...:..|
|00001120| 08 40 c3 3d 87 22 20 5b | 66 75 6e 63 74 69 6f 6e |.@.=." [|function|
|00001130| 20 66 62 6f 75 6e 64 70 | 20 63 6f 6d 70 69 6c 65 | fboundp| compile|
|00001140| 64 2d 66 75 6e 63 74 69 | 6f 6e 2d 70 20 6c 61 6d |d-functi|on-p lam|
|00001150| 62 64 61 5d 20 32 20 22 | 5c 0a 43 68 65 63 6b 20 |bda] 2 "|\.Check |
|00001160| 77 68 65 74 68 65 72 20 | 46 55 4e 43 54 49 4f 4e |whether |FUNCTION|
|00001170| 20 69 73 20 61 20 76 61 | 6c 69 64 20 66 75 6e 63 | is a va|lid func|
|00001180| 74 69 6f 6e 20 6f 62 6a | 65 63 74 20 74 6f 20 62 |tion obj|ect to b|
|00001190| 65 20 75 73 65 64 20 0a | 61 73 20 28 64 69 73 70 |e used .|as (disp|
|000011a0| 61 74 63 68 29 20 6d 61 | 63 72 6f 20 63 68 61 72 |atch) ma|cro char|
|000011b0| 61 63 74 65 72 20 66 75 | 6e 63 74 69 6f 6e 2e 22 |acter fu|nction."|
|000011c0| 5d 29 0a 28 62 79 74 65 | 2d 63 6f 64 65 20 22 c0 |]).(byte|-code ".|
|000011d0| c1 21 ac 82 c2 11 c0 c3 | 21 ac 82 c2 13 c2 14 c2 |.!......|!.......|
|000011e0| 15 c2 87 22 20 5b 62 6f | 75 6e 64 70 20 72 65 61 |..." [bo|undp rea|
|000011f0| 64 65 72 3a 73 68 61 72 | 65 64 2d 73 74 72 75 63 |der:shar|ed-struc|
|00001200| 74 75 72 65 2d 72 65 66 | 65 72 65 6e 63 65 73 20 |ture-ref|erences |
|00001210| 6e 69 6c 20 72 65 61 64 | 65 72 3a 73 68 61 72 65 |nil read|er:share|
|00001220| 64 2d 73 74 72 75 63 74 | 75 72 65 2d 6c 61 62 65 |d-struct|ure-labe|
|00001230| 6c 73 20 62 65 66 6f 72 | 65 2d 72 65 61 64 2d 68 |ls befor|e-read-h|
|00001240| 6f 6f 6b 20 61 66 74 65 | 72 2d 72 65 61 64 2d 68 |ook afte|r-read-h|
|00001250| 6f 6f 6b 5d 20 32 29 0a | 28 66 73 65 74 20 27 72 |ook] 2).|(fset 'r|
|00001260| 65 61 64 65 72 3a 65 6e | 63 61 70 73 75 6c 61 74 |eader:en|capsulat|
|00001270| 65 2d 72 65 63 75 72 73 | 69 76 65 2d 63 61 6c 6c |e-recurs|ive-call|
|00001280| 20 27 28 6d 61 63 72 6f | 20 2e 20 23 5b 28 72 65 | '(macro| . #[(re|
|00001290| 61 64 65 72 2d 63 61 6c | 6c 29 20 22 c0 c1 c2 c3 |ader-cal|l) "....|
|000012a0| c4 c5 0e 06 c7 42 42 44 | 45 c8 42 42 42 87 22 20 |.....BBD|E.BBB." |
|000012b0| 5b 70 72 6f 67 32 20 28 | 72 75 6e 2d 68 6f 6f 6b |[prog2 (|run-hook|
|000012c0| 73 20 27 62 65 66 6f 72 | 65 2d 72 65 61 64 2d 68 |s 'befor|e-read-h|
|000012d0| 6f 6f 6b 29 20 63 61 74 | 63 68 20 27 72 65 61 64 |ook) cat|ch 'read|
|000012e0| 65 72 2d 69 67 6e 6f 72 | 65 20 72 65 74 75 72 6e |er-ignor|e return|
|000012f0| 20 70 72 6f 67 31 20 72 | 65 61 64 65 72 2d 63 61 | prog1 r|eader-ca|
|00001300| 6c 6c 20 28 28 72 75 6e | 2d 68 6f 6f 6b 73 20 27 |ll ((run|-hooks '|
|00001310| 61 66 74 65 72 2d 72 65 | 61 64 2d 68 6f 6f 6b 29 |after-re|ad-hook)|
|00001320| 29 20 28 28 72 75 6e 2d | 68 6f 6f 6b 73 20 27 61 |) ((run-|hooks 'a|
|00001330| 66 74 65 72 2d 72 65 61 | 64 2d 68 6f 6f 6b 29 29 |fter-rea|d-hook))|
|00001340| 5d 20 38 20 22 5c 0a 45 | 6e 63 61 70 73 75 6c 61 |] 8 "\.E|ncapsula|
|00001350| 74 65 20 52 45 41 44 45 | 52 2d 43 41 4c 4c 2c 20 |te READE|R-CALL, |
|00001360| 61 20 66 6f 72 6d 20 74 | 68 61 74 20 63 6f 6e 74 |a form t|hat cont|
|00001370| 61 69 6e 73 20 61 20 72 | 65 63 75 72 73 69 76 65 |ains a r|ecursive|
|00001380| 20 63 61 6c 6c 20 74 6f | 20 74 68 65 0a 72 65 61 | call to| the.rea|
|00001390| 64 65 72 2c 20 66 6f 72 | 20 75 73 61 67 65 20 69 |der, for| usage i|
|000013a0| 6e 73 69 64 65 20 74 68 | 65 20 6d 61 69 6e 20 72 |nside th|e main r|
|000013b0| 65 61 64 65 72 20 6c 6f | 6f 70 2e 20 20 54 68 65 |eader lo|op. The|
|000013c0| 20 6d 61 63 72 6f 20 77 | 72 61 70 73 20 74 77 6f | macro w|raps two|
|000013d0| 0a 68 6f 6f 6b 73 20 61 | 72 6f 75 6e 64 20 52 45 |.hooks a|round RE|
|000013e0| 41 44 45 52 2d 43 41 4c | 4c 3a 20 60 62 65 66 6f |ADER-CAL|L: `befo|
|000013f0| 72 65 2d 72 65 61 64 2d | 68 6f 6f 6b 27 20 61 6e |re-read-|hook' an|
|00001400| 64 20 60 61 66 74 65 72 | 2d 72 65 61 64 2d 68 6f |d `after|-read-ho|
|00001410| 6f 6b 27 2e 20 0a 0a 49 | 66 20 52 45 41 44 45 52 |ok'. ..I|f READER|
|00001420| 2d 43 41 4c 4c 20 72 65 | 74 75 72 6e 73 20 6e 6f |-CALL re|turns no|
|00001430| 72 6d 61 6c 6c 79 2c 20 | 74 68 65 20 6d 61 63 72 |rmally, |the macr|
|00001440| 6f 20 65 78 69 74 73 20 | 69 6d 6d 65 64 69 61 74 |o exits |immediat|
|00001450| 65 6c 79 20 66 72 6f 6d | 20 74 68 65 0a 73 75 72 |ely from| the.sur|
|00001460| 72 6f 75 6e 64 69 6e 67 | 20 6c 6f 6f 70 20 77 69 |rounding| loop wi|
|00001470| 74 68 20 74 68 65 20 76 | 61 6c 75 65 20 6f 66 20 |th the v|alue of |
|00001480| 52 45 41 44 45 52 2d 43 | 41 4c 4c 20 61 73 20 72 |READER-C|ALL as r|
|00001490| 65 73 75 6c 74 2e 20 20 | 49 66 20 69 74 20 65 78 |esult. |If it ex|
|000014a0| 69 74 73 0a 6e 6f 6e 2d | 6c 6f 63 61 6c 6c 79 20 |its.non-|locally |
|000014b0| 28 77 69 74 68 20 74 61 | 67 20 60 72 65 61 64 65 |(with ta|g `reade|
|000014c0| 72 2d 69 67 6e 6f 72 65 | 27 29 2c 20 69 74 20 6a |r-ignore|'), it j|
|000014d0| 75 73 74 20 72 65 74 75 | 72 6e 73 20 74 68 65 20 |ust retu|rns the |
|000014e0| 76 61 6c 75 65 20 6f 66 | 0a 52 45 41 44 45 52 2d |value of|.READER-|
|000014f0| 43 41 4c 4c 2c 20 69 6e | 20 77 68 69 63 68 20 63 |CALL, in| which c|
|00001500| 61 73 65 20 74 68 65 20 | 73 75 72 72 6f 75 6e 64 |ase the |surround|
|00001510| 69 6e 67 20 72 65 61 64 | 65 72 20 6c 6f 6f 70 20 |ing read|er loop |
|00001520| 63 6f 6e 74 69 6e 75 65 | 73 20 69 74 73 0a 65 78 |continue|s its.ex|
|00001530| 65 63 75 74 69 6f 6e 2e | 0a 0a 49 6e 20 62 6f 74 |ecution.|..In bot|
|00001540| 68 20 63 61 73 65 73 2c | 20 60 62 65 66 6f 72 65 |h cases,| `before|
|00001550| 2d 72 65 61 64 2d 68 6f | 6f 6b 27 20 61 6e 64 20 |-read-ho|ok' and |
|00001560| 60 61 66 74 65 72 2d 72 | 65 61 64 2d 68 6f 6f 6b |`after-r|ead-hook|
|00001570| 27 20 61 72 65 20 63 61 | 6c 6c 65 64 0a 62 65 66 |' are ca|lled.bef|
|00001580| 6f 72 65 20 61 6e 64 20 | 61 66 74 65 72 20 65 78 |ore and |after ex|
|00001590| 65 63 75 74 69 6e 67 20 | 52 45 41 44 45 52 2d 43 |ecuting |READER-C|
|000015a0| 41 4c 4c 2e 22 5d 29 29 | 0a 28 62 79 74 65 2d 63 |ALL."]))|.(byte-c|
|000015b0| 6f 64 65 20 22 c0 c1 21 | ac 84 c2 c3 21 11 c4 c5 |ode "..!|....!...|
|000015c0| 21 ac 85 c5 c6 4b 4d 88 | c0 87 22 20 5b 62 6f 75 |!....KM.|.." [bou|
|000015d0| 6e 64 70 20 72 65 61 64 | 65 72 3a 74 6d 70 2d 62 |ndp read|er:tmp-b|
|000015e0| 75 66 66 65 72 20 67 65 | 74 2d 62 75 66 66 65 72 |uffer ge|t-buffer|
|000015f0| 2d 63 72 65 61 74 65 20 | 22 20 2a 43 4c 20 52 65 |-create |" *CL Re|
|00001600| 61 64 2a 22 20 66 62 6f | 75 6e 64 70 20 72 65 61 |ad*" fbo|undp rea|
|00001610| 64 65 72 3a 6f 72 69 67 | 69 6e 61 6c 2d 72 65 61 |der:orig|inal-rea|
|00001620| 64 2d 66 72 6f 6d 2d 73 | 74 72 69 6e 67 20 72 65 |d-from-s|tring re|
|00001630| 61 64 2d 66 72 6f 6d 2d | 73 74 72 69 6e 67 5d 20 |ad-from-|string] |
|00001640| 32 29 0a 28 66 73 65 74 | 20 27 72 65 61 64 65 72 |2).(fset| 'reader|
|00001650| 3a 72 65 61 64 2d 66 72 | 6f 6d 2d 73 74 72 69 6e |:read-fr|om-strin|
|00001660| 67 20 23 5b 28 73 74 72 | 69 6e 67 20 26 6f 70 74 |g #[(str|ing &opt|
|00001670| 69 6f 6e 61 6c 20 73 74 | 61 72 74 20 65 6e 64 29 |ional st|art end)|
|00001680| 20 22 08 ac 82 c1 10 5c | 6e ac 83 0b 47 12 8a 0c | ".....\|n...G...|
|00001690| 71 88 c5 c6 21 88 c7 20 | 88 0b c1 5c 6e 4f 63 88 |q...!.. |...\nOc.|
|000016a0| 08 54 62 88 c8 0c c9 5c | 22 60 53 29 42 87 22 20 |.Tb....\|"`S)B." |
|000016b0| 5b 73 74 61 72 74 20 30 | 20 65 6e 64 20 73 74 72 |[start 0| end str|
|000016c0| 69 6e 67 20 72 65 61 64 | 65 72 3a 74 6d 70 2d 62 |ing read|er:tmp-b|
|000016d0| 75 66 66 65 72 20 61 75 | 74 6f 2d 73 61 76 65 2d |uffer au|to-save-|
|000016e0| 6d 6f 64 65 20 2d 31 20 | 65 72 61 73 65 2d 62 75 |mode -1 |erase-bu|
|000016f0| 66 66 65 72 20 72 65 61 | 64 65 72 3a 72 65 61 64 |ffer rea|der:read|
|00001700| 2d 66 72 6f 6d 2d 62 75 | 66 66 65 72 20 6e 69 6c |-from-bu|ffer nil|
|00001710| 5d 20 33 20 22 5c 0a 52 | 65 61 64 20 6f 6e 65 20 |] 3 "\.R|ead one |
|00001720| 4c 69 73 70 20 65 78 70 | 72 65 73 73 69 6f 6e 20 |Lisp exp|ression |
|00001730| 77 68 69 63 68 20 69 73 | 20 72 65 70 72 65 73 65 |which is| represe|
|00001740| 6e 74 65 64 20 61 73 20 | 74 65 78 74 20 62 79 20 |nted as |text by |
|00001750| 53 54 52 49 4e 47 2e 0a | 52 65 74 75 72 6e 73 20 |STRING..|Returns |
|00001760| 61 20 63 6f 6e 73 3a 20 | 28 4f 42 4a 45 43 54 2d |a cons: |(OBJECT-|
|00001770| 52 45 41 44 20 2e 20 46 | 49 4e 41 4c 2d 53 54 52 |READ . F|INAL-STR|
|00001780| 49 4e 47 2d 49 4e 44 45 | 58 29 2e 0a 53 54 41 52 |ING-INDE|X)..STAR|
|00001790| 54 20 61 6e 64 20 45 4e | 44 20 6f 70 74 69 6f 6e |T and EN|D option|
|000017a0| 61 6c 6c 79 20 64 65 6c | 69 6d 69 74 20 61 20 73 |ally del|imit a s|
|000017b0| 75 62 73 74 72 69 6e 67 | 20 6f 66 20 53 54 52 49 |ubstring| of STRI|
|000017c0| 4e 47 20 66 72 6f 6d 20 | 77 68 69 63 68 20 74 6f |NG from |which to|
|000017d0| 20 72 65 61 64 3b 0a 20 | 74 68 65 79 20 64 65 66 | read;. |they def|
|000017e0| 61 75 6c 74 20 74 6f 20 | 30 20 61 6e 64 20 28 6c |ault to |0 and (l|
|000017f0| 65 6e 67 74 68 20 53 54 | 52 49 4e 47 29 20 72 65 |ength ST|RING) re|
|00001800| 73 70 65 63 74 69 76 65 | 6c 79 2e 0a 0a 54 68 69 |spective|ly...Thi|
|00001810| 73 20 69 73 20 74 68 65 | 20 63 6c 2d 72 65 61 64 |s is the| cl-read|
|00001820| 20 72 65 70 6c 61 63 65 | 6d 65 6e 74 20 6f 66 20 | replace|ment of |
|00001830| 74 68 65 20 73 74 61 6e | 64 61 72 64 20 65 6c 69 |the stan|dard eli|
|00001840| 73 70 20 66 75 6e 63 74 | 69 6f 6e 0a 60 72 65 61 |sp funct|ion.`rea|
|00001850| 64 2d 66 72 6f 6d 2d 73 | 74 72 69 6e 67 27 2e 22 |d-from-s|tring'."|
|00001860| 5d 29 0a 28 62 79 74 65 | 2d 63 6f 64 65 20 22 c0 |]).(byte|-code ".|
|00001870| c1 21 ac 85 c1 c2 4b 4d | 88 c0 87 22 20 5b 66 62 |.!....KM|..." [fb|
|00001880| 6f 75 6e 64 70 20 72 65 | 61 64 65 72 3a 6f 72 69 |oundp re|ader:ori|
|00001890| 67 69 6e 61 6c 2d 72 65 | 61 64 20 72 65 61 64 5d |ginal-re|ad read]|
|000018a0| 20 32 29 0a 28 66 73 65 | 74 20 27 72 65 61 64 65 | 2).(fse|t 'reade|
|000018b0| 72 3a 72 65 61 64 20 23 | 5b 28 26 6f 70 74 69 6f |r:read #|[(&optio|
|000018c0| 6e 61 6c 20 73 74 72 65 | 61 6d 20 72 65 63 75 72 |nal stre|am recur|
|000018d0| 73 69 76 65 2d 70 29 20 | 22 08 ac 84 c1 5c 6e 21 |sive-p) |"....\n!|
|000018e0| 87 5c 6e ac 82 0b 12 5c | 6e c4 3d ab 84 c5 c6 21 |.\n....\|n.=....!|
|000018f0| 12 c7 5c 6e 21 ab 86 c8 | 5c 6e 0e 09 5c 22 87 ca |..\n!...|\n..\"..|
|00001900| 5c 6e 21 ab 92 8a cb 5c | 6e 21 71 88 cc 5c 6e 21 |\n!....\|n!q..\n!|
|00001910| 62 88 c8 70 0e 09 5c 22 | 29 87 5c 6e 3b ab 9a 8a |b..p..\"|).\n;...|
|00001920| 0e 0d 71 88 ce cf 21 88 | d0 20 88 5c 6e 63 88 65 |..q...!.|. .\nc.e|
|00001930| 62 88 c8 0e 0d 0e 09 5c | 22 29 87 d1 d2 5c 6e 5c |b......\|")...\n\|
|00001940| 22 87 22 20 5b 63 6c 2d | 72 65 61 64 2d 61 63 74 |"." [cl-|read-act|
|00001950| 69 76 65 20 72 65 61 64 | 65 72 3a 6f 72 69 67 69 |ive read|er:origi|
|00001960| 6e 61 6c 2d 72 65 61 64 | 20 73 74 72 65 61 6d 20 |nal-read| stream |
|00001970| 73 74 61 6e 64 61 72 64 | 2d 69 6e 70 75 74 20 74 |standard|-input t|
|00001980| 20 72 65 61 64 2d 66 72 | 6f 6d 2d 6d 69 6e 69 62 | read-fr|om-minib|
|00001990| 75 66 66 65 72 20 22 43 | 6f 6d 6d 6f 6e 20 4c 69 |uffer "C|ommon Li|
|000019a0| 73 70 20 45 78 70 72 65 | 73 73 69 6f 6e 3a 20 22 |sp Expre|ssion: "|
|000019b0| 20 62 75 66 66 65 72 70 | 20 72 65 61 64 65 72 3a | bufferp| reader:|
|000019c0| 72 65 61 64 2d 66 72 6f | 6d 2d 62 75 66 66 65 72 |read-fro|m-buffer|
|000019d0| 20 72 65 63 75 72 73 69 | 76 65 2d 70 20 6d 61 72 | recursi|ve-p mar|
|000019e0| 6b 65 72 70 20 6d 61 72 | 6b 65 72 2d 62 75 66 66 |kerp mar|ker-buff|
|000019f0| 65 72 20 6d 61 72 6b 65 | 72 2d 70 6f 73 69 74 69 |er marke|r-positi|
|00001a00| 6f 6e 20 72 65 61 64 65 | 72 3a 74 6d 70 2d 62 75 |on reade|r:tmp-bu|
|00001a10| 66 66 65 72 20 61 75 74 | 6f 2d 73 61 76 65 2d 6d |ffer aut|o-save-m|
|00001a20| 6f 64 65 20 2d 31 20 65 | 72 61 73 65 2d 62 75 66 |ode -1 e|rase-buf|
|00001a30| 66 65 72 20 65 72 72 6f | 72 20 22 43 4c 20 72 65 |fer erro|r "CL re|
|00001a40| 61 64 65 72 20 65 72 72 | 6f 72 3a 20 4e 6f 74 20 |ader err|or: Not |
|00001a50| 61 20 76 61 6c 69 64 20 | 73 74 72 65 61 6d 3a 20 |a valid |stream: |
|00001a60| 25 73 22 5d 20 33 20 22 | 5c 0a 52 65 61 64 20 6f |%s"] 3 "|\.Read o|
|00001a70| 6e 65 20 4c 69 73 70 20 | 65 78 70 72 65 73 73 69 |ne Lisp |expressi|
|00001a80| 6f 6e 20 61 73 20 74 65 | 78 74 20 66 72 6f 6d 20 |on as te|xt from |
|00001a90| 53 54 52 45 41 4d 2c 20 | 72 65 74 75 72 6e 20 61 |STREAM, |return a|
|00001aa0| 73 20 4c 69 73 70 20 6f | 62 6a 65 63 74 2e 0a 49 |s Lisp o|bject..I|
|00001ab0| 66 20 53 54 52 45 41 4d | 20 69 73 20 6e 69 6c 2c |f STREAM| is nil,|
|00001ac0| 20 75 73 65 20 74 68 65 | 20 76 61 6c 75 65 20 6f | use the| value o|
|00001ad0| 66 20 60 73 74 61 6e 64 | 61 72 64 2d 69 6e 70 75 |f `stand|ard-inpu|
|00001ae0| 74 27 20 28 77 68 69 63 | 68 20 73 65 65 29 2e 0a |t' (whic|h see)..|
|00001af0| 53 54 52 45 41 4d 20 6f | 72 20 74 68 65 20 76 61 |STREAM o|r the va|
|00001b00| 6c 75 65 20 6f 66 20 60 | 73 74 61 6e 64 61 72 64 |lue of `|standard|
|00001b10| 2d 69 6e 70 75 74 27 20 | 6d 61 79 20 62 65 3a 0a |-input' |may be:.|
|00001b20| 20 61 20 62 75 66 66 65 | 72 20 28 72 65 61 64 20 | a buffe|r (read |
|00001b30| 66 72 6f 6d 20 70 6f 69 | 6e 74 20 61 6e 64 20 61 |from poi|nt and a|
|00001b40| 64 76 61 6e 63 65 20 69 | 74 29 0a 20 61 20 6d 61 |dvance i|t). a ma|
|00001b50| 72 6b 65 72 20 28 72 65 | 61 64 20 66 72 6f 6d 20 |rker (re|ad from |
|00001b60| 77 68 65 72 65 20 69 74 | 20 70 6f 69 6e 74 73 20 |where it| points |
|00001b70| 61 6e 64 20 61 64 76 61 | 6e 63 65 20 69 74 29 0a |and adva|nce it).|
|00001b80| 20 61 20 73 74 72 69 6e | 67 20 28 74 61 6b 65 73 | a strin|g (takes|
|00001b90| 20 74 65 78 74 20 66 72 | 6f 6d 20 73 74 72 69 6e | text fr|om strin|
|00001ba0| 67 2c 20 73 74 61 72 74 | 69 6e 67 20 61 74 20 74 |g, start|ing at t|
|00001bb0| 68 65 20 62 65 67 69 6e | 6e 69 6e 67 29 0a 20 74 |he begin|ning). t|
|00001bc0| 20 28 72 65 61 64 20 74 | 65 78 74 20 6c 69 6e 65 | (read t|ext line|
|00001bd0| 20 75 73 69 6e 67 20 6d | 69 6e 69 62 75 66 66 65 | using m|inibuffe|
|00001be0| 72 20 61 6e 64 20 75 73 | 65 20 69 74 29 2e 0a 0a |r and us|e it)...|
|00001bf0| 54 68 69 73 20 69 73 20 | 74 68 65 20 63 6c 2d 72 |This is |the cl-r|
|00001c00| 65 61 64 20 72 65 70 6c | 61 63 65 6d 65 6e 74 20 |ead repl|acement |
|00001c10| 6f 66 20 74 68 65 20 73 | 74 61 6e 64 61 72 64 20 |of the s|tandard |
|00001c20| 65 6c 69 73 70 20 66 75 | 6e 63 74 69 6f 6e 0a 60 |elisp fu|nction.`|
|00001c30| 72 65 61 64 27 2e 20 54 | 68 65 20 6f 6e 6c 79 20 |read'. T|he only |
|00001c40| 69 6e 63 6f 6d 70 61 74 | 69 62 69 6c 69 74 79 20 |incompat|ibility |
|00001c50| 69 73 20 74 68 61 74 20 | 66 75 6e 63 74 69 6f 6e |is that |function|
|00001c60| 73 20 61 73 20 73 74 72 | 65 61 6d 20 61 72 67 75 |s as str|eam argu|
|00001c70| 6d 65 6e 74 73 0a 61 72 | 65 20 6e 6f 74 20 73 75 |ments.ar|e not su|
|00001c80| 70 70 6f 72 74 65 64 2e | 22 5d 29 0a 28 62 79 74 |pported.|"]).(byt|
|00001c90| 65 2d 63 6f 64 65 20 22 | c0 c1 4d 88 c2 c3 c4 c5 |e-code "|..M.....|
|00001ca0| 23 88 c2 c3 c6 c7 23 88 | c8 c9 4d 87 22 20 5b 72 |#.....#.|..M." [r|
|00001cb0| 65 61 64 65 72 3a 72 65 | 61 64 2d 66 72 6f 6d 2d |eader:re|ad-from-|
|00001cc0| 62 75 66 66 65 72 20 23 | 5b 28 26 6f 70 74 69 6f |buffer #|[(&optio|
|00001cd0| 6e 61 6c 20 73 74 72 65 | 61 6d 20 72 65 63 75 72 |nal stre|am recur|
|00001ce0| 73 69 76 65 2d 70 29 20 | 22 c0 09 21 ac 84 c2 c3 |sive-p) |"..!....|
|00001cf0| 21 88 0c ac 8e c5 89 1e | 06 1e 07 c8 c9 09 ca 5c |!.......|.......\|
|00001d00| 22 21 2a 87 cb cc 8d 87 | 22 20 5b 62 75 66 66 65 |"!*.....|" [buffe|
|00001d10| 72 70 20 73 74 72 65 61 | 6d 20 65 72 72 6f 72 20 |rp strea|m error |
|00001d20| 22 53 6f 72 72 79 2c 20 | 63 61 6e 20 6f 6e 6c 79 |"Sorry, |can only|
|00001d30| 20 72 65 61 64 20 6f 6e | 20 62 75 66 66 65 72 73 | read on| buffers|
|00001d40| 22 20 72 65 63 75 72 73 | 69 76 65 2d 70 20 6e 69 |" recurs|ive-p ni|
|00001d50| 6c 20 72 65 61 64 65 72 | 3a 73 68 61 72 65 64 2d |l reader|:shared-|
|00001d60| 73 74 72 75 63 74 75 72 | 65 2d 6c 61 62 65 6c 73 |structur|e-labels|
|00001d70| 20 72 65 61 64 65 72 3a | 73 68 61 72 65 64 2d 73 | reader:|shared-s|
|00001d80| 74 72 75 63 74 75 72 65 | 2d 72 65 66 65 72 65 6e |tructure|-referen|
|00001d90| 63 65 73 20 72 65 61 64 | 65 72 3a 72 65 73 74 6f |ces read|er:resto|
|00001da0| 72 65 2d 73 68 61 72 65 | 64 2d 73 74 72 75 63 74 |re-share|d-struct|
|00001db0| 75 72 65 20 72 65 61 64 | 65 72 3a 72 65 61 64 2d |ure read|er:read-|
|00001dc0| 66 72 6f 6d 2d 62 75 66 | 66 65 72 20 74 20 2d 2d |from-buf|fer t --|
|00001dd0| 63 6c 2d 62 6c 6f 63 6b | 2d 6e 69 6c 2d 2d 20 28 |cl-block|-nil-- (|
|00001de0| 62 79 74 65 2d 63 6f 64 | 65 20 22 c0 19 c0 1a 67 |byte-cod|e "....g|
|00001df0| 11 0b 09 48 12 6d ab 84 | c4 c5 21 88 5c 6e c6 3d |...H.m..|..!.\n.=|
|00001e00| ab 87 c4 c7 09 5c 22 88 | aa 67 5c 6e c8 3d ab 8f |.....\".|.g\n.=..|
|00001e10| c9 75 88 0b 67 48 c8 3d | ab 58 c9 75 88 aa 74 5c |.u..gH.=|.X.u..t\|
|00001e20| 6e ca 3d ab 8e cb cc 21 | 88 cd ce 8d 88 cb cf 21 |n.=....!|.......!|
|00001e30| 88 aa 40 d0 5c 6e 21 ab | 8e cb cc 21 88 cd d1 8d |..@.\n!.|...!....|
|00001e40| 88 cb cf 21 88 aa 2d cb | cc 21 88 cd d2 8d 88 cb |...!..-.|.!......|
|00001e50| cf 21 88 aa 1f 22 20 5b | 6e 69 6c 20 63 68 61 72 |.!..." [|nil char|
|00001e60| 20 65 6e 74 72 79 20 2a | 72 65 61 64 74 61 62 6c | entry *|readtabl|
|00001e70| 65 2a 20 65 72 72 6f 72 | 20 22 43 4c 20 72 65 61 |e* error| "CL rea|
|00001e80| 64 20 65 72 72 6f 72 3a | 20 45 6e 64 20 6f 66 20 |d error:| End of |
|00001e90| 66 69 6c 65 20 64 75 72 | 69 6e 67 20 72 65 61 64 |file dur|ing read|
|00001ea0| 69 6e 67 22 20 69 6c 6c | 65 67 61 6c 20 22 43 4c |ing" ill|egal "CL|
|00001eb0| 20 72 65 61 64 20 65 72 | 72 6f 72 3a 20 60 25 63 | read er|ror: `%c|
|00001ec0| 27 20 68 61 73 20 69 6c | 6c 65 67 61 6c 20 63 68 |' has il|legal ch|
|00001ed0| 61 72 61 63 74 65 72 20 | 73 79 6e 74 61 78 22 20 |aracter |syntax" |
|00001ee0| 77 68 69 74 65 73 70 61 | 63 65 20 31 20 63 6f 6e |whitespa|ce 1 con|
|00001ef0| 73 74 69 74 75 65 6e 74 | 20 72 75 6e 2d 68 6f 6f |stituent| run-hoo|
|00001f00| 6b 73 20 62 65 66 6f 72 | 65 2d 72 65 61 64 2d 68 |ks befor|e-read-h|
|00001f10| 6f 6f 6b 20 72 65 61 64 | 65 72 2d 69 67 6e 6f 72 |ook read|er-ignor|
|00001f20| 65 20 28 62 79 74 65 2d | 63 6f 64 65 20 22 c0 c1 |e (byte-|code "..|
|00001f30| c2 0b 21 c4 c5 21 88 5c | 22 87 22 20 5b 74 68 72 |..!..!.\|"." [thr|
|00001f40| 6f 77 20 2d 2d 63 6c 2d | 62 6c 6f 63 6b 2d 6e 69 |ow --cl-|block-ni|
|00001f50| 6c 2d 2d 20 72 65 61 64 | 65 72 3a 72 65 61 64 2d |l-- read|er:read-|
|00001f60| 63 6f 6e 73 74 69 74 75 | 65 6e 74 20 73 74 72 65 |constitu|ent stre|
|00001f70| 61 6d 20 72 75 6e 2d 68 | 6f 6f 6b 73 20 61 66 74 |am run-h|ooks aft|
|00001f80| 65 72 2d 72 65 61 64 2d | 68 6f 6f 6b 5d 20 35 29 |er-read-|hook] 5)|
|00001f90| 20 61 66 74 65 72 2d 72 | 65 61 64 2d 68 6f 6f 6b | after-r|ead-hook|
|00001fa0| 20 76 65 63 74 6f 72 70 | 20 28 62 79 74 65 2d 63 | vectorp| (byte-c|
|00001fb0| 6f 64 65 20 22 c0 c1 c2 | 1b c2 1c c5 75 88 67 c5 |ode "...|....u.g.|
|00001fc0| 75 88 89 13 c6 3e ab 87 | 0c 0b 43 a4 14 aa 6f 0e |u....>..|..C...o.|
|00001fd0| 07 0b 48 ae 84 c8 c9 0b | 5c 22 0e 5c 6e 0b cb cc |..H.....|\".\n...|
|00001fe0| cd ce cf 0c 5c 22 5c 22 | 21 23 2a d0 d1 21 88 5c |....\"\"|!#*..!.\|
|00001ff0| 22 87 22 20 5b 74 68 72 | 6f 77 20 2d 2d 63 6c 2d |"." [thr|ow --cl-|
|00002000| 62 6c 6f 63 6b 2d 6e 69 | 6c 2d 2d 20 6e 69 6c 20 |block-ni|l-- nil |
|00002010| 73 75 62 2d 63 68 61 72 | 20 64 69 67 69 74 2d 61 |sub-char| digit-a|
|00002020| 72 67 73 20 31 20 28 34 | 38 20 34 39 20 35 30 20 |rgs 1 (4|8 49 50 |
|00002030| 35 31 20 35 32 20 35 33 | 20 35 34 20 35 35 20 35 |51 52 53| 54 55 5|
|00002040| 36 20 35 37 29 20 65 6e | 74 72 79 20 65 72 72 6f |6 57) en|try erro|
|00002050| 72 20 22 43 6c 20 72 65 | 61 64 65 72 20 65 72 72 |r "Cl re|ader err|
|00002060| 6f 72 3a 20 75 6e 64 65 | 66 69 6e 65 64 20 73 75 |or: unde|fined su|
|00002070| 62 73 65 71 75 65 6e 74 | 20 64 69 73 70 61 74 63 |bsequent| dispatc|
|00002080| 68 20 63 68 61 72 61 63 | 74 65 72 20 60 25 63 27 |h charac|ter `%c'|
|00002090| 22 20 73 74 72 65 61 6d | 20 73 74 72 69 6e 67 2d |" stream| string-|
|000020a0| 74 6f 2d 69 6e 74 20 61 | 70 70 6c 79 20 63 6f 6e |to-int a|pply con|
|000020b0| 63 61 74 20 6d 61 70 63 | 61 72 20 63 68 61 72 2d |cat mapc|ar char-|
|000020c0| 74 6f 2d 73 74 72 69 6e | 67 20 72 75 6e 2d 68 6f |to-strin|g run-ho|
|000020d0| 6f 6b 73 20 61 66 74 65 | 72 2d 72 65 61 64 2d 68 |oks afte|r-read-h|
|000020e0| 6f 6f 6b 5d 20 31 32 29 | 20 28 62 79 74 65 2d 63 |ook] 12)| (byte-c|
|000020f0| 6f 64 65 20 22 c0 c1 c2 | 75 88 0b 0c 0d 5c 22 c6 |ode "...|u....\".|
|00002100| c7 21 88 5c 22 87 22 20 | 5b 74 68 72 6f 77 20 2d |.!.\"." |[throw -|
|00002110| 2d 63 6c 2d 62 6c 6f 63 | 6b 2d 6e 69 6c 2d 2d 20 |-cl-bloc|k-nil-- |
|00002120| 31 20 65 6e 74 72 79 20 | 73 74 72 65 61 6d 20 63 |1 entry |stream c|
|00002130| 68 61 72 20 72 75 6e 2d | 68 6f 6f 6b 73 20 61 66 |har run-|hooks af|
|00002140| 74 65 72 2d 72 65 61 64 | 2d 68 6f 6f 6b 5d 20 35 |ter-read|-hook] 5|
|00002150| 29 5d 20 33 29 5d 20 34 | 5d 20 70 75 74 20 72 65 |)] 3)] 4|] put re|
|00002160| 61 64 65 72 3a 65 6e 63 | 61 70 73 75 6c 61 74 65 |ader:enc|apsulate|
|00002170| 2d 72 65 63 75 72 73 69 | 76 65 2d 63 61 6c 6c 20 |-recursi|ve-call |
|00002180| 65 64 65 62 75 67 2d 66 | 6f 72 6d 2d 73 70 65 63 |edebug-f|orm-spec|
|00002190| 20 28 66 6f 72 6d 29 20 | 6c 69 73 70 2d 69 6e 64 | (form) |lisp-ind|
|000021a0| 65 6e 74 2d 66 75 6e 63 | 74 69 6f 6e 20 30 20 72 |ent-func|tion 0 r|
|000021b0| 65 61 64 65 72 3a 72 65 | 61 64 2d 63 6f 6e 73 74 |eader:re|ad-const|
|000021c0| 69 74 75 65 6e 74 20 23 | 5b 28 73 74 72 65 61 6d |ituent #|[(stream|
|000021d0| 29 20 22 c0 09 21 5c 6e | 68 48 c3 3d ac 83 c4 75 |) "..!\n|hH.=...u|
|000021e0| 88 87 22 20 5b 72 65 61 | 64 65 72 3a 6f 72 69 67 |.." [rea|der:orig|
|000021f0| 69 6e 61 6c 2d 72 65 61 | 64 20 73 74 72 65 61 6d |inal-rea|d stream|
|00002200| 20 2a 72 65 61 64 74 61 | 62 6c 65 2a 20 63 6f 6e | *readta|ble* con|
|00002210| 73 74 69 74 75 65 6e 74 | 20 2d 31 5d 20 33 5d 5d |stituent| -1] 3]]|
|00002220| 20 34 29 0a 28 64 65 66 | 63 6f 6e 73 74 20 72 65 | 4).(def|const re|
|00002230| 61 64 65 72 3a 69 6e 74 | 65 72 6e 61 6c 2d 73 74 |ader:int|ernal-st|
|00002240| 61 6e 64 61 72 64 2d 72 | 65 61 64 74 61 62 6c 65 |andard-r|eadtable|
|00002250| 20 28 62 79 74 65 2d 63 | 6f 64 65 20 22 c0 09 54 | (byte-c|ode "..T|
|00002260| c2 5c 22 1b c4 1d c6 1e | 07 0b 09 c8 49 88 0d 3a |.\".....|....I..:|
|00002270| ab ac 0d 40 89 16 07 41 | 1e 09 c6 1e 5c 6e 0e 09 |...@...A|....\n..|
|00002280| 3a ab 95 0e 09 40 16 5c | 6e 0b 0e 5c 6e 0e 07 40 |:....@.\|n..\n..@|
|00002290| 49 88 0e 09 41 89 16 09 | aa 68 2a 0d 41 89 15 aa |I...A...|.h*.A...|
|000022a0| 51 0b 2b 87 22 20 5b 6d | 61 6b 65 2d 76 65 63 74 |Q.+." [m|ake-vect|
|000022b0| 6f 72 20 72 65 61 64 65 | 72 3a 72 65 61 64 74 61 |or reade|r:readta|
|000022c0| 62 6c 65 2d 73 69 7a 65 | 20 69 6c 6c 65 67 61 6c |ble-size| illegal|
|000022d0| 20 72 61 77 2d 72 65 61 | 64 74 61 62 6c 65 20 28 | raw-rea|dtable (|
|000022e0| 28 63 6f 6e 73 74 69 74 | 75 65 6e 74 20 33 33 20 |(constit|uent 33 |
|000022f0| 36 34 20 33 36 20 33 37 | 20 33 38 20 34 32 20 39 |64 36 37| 38 42 9|
|00002300| 35 20 34 35 20 34 33 20 | 36 31 20 34 37 20 39 32 |5 45 43 |61 47 92|
|00002310| 20 34 38 20 34 39 20 35 | 30 20 35 31 20 35 32 20 | 48 49 5|0 51 52 |
|00002320| 35 33 20 35 34 20 35 35 | 20 35 36 20 35 37 20 35 |53 54 55| 56 57 5|
|00002330| 38 20 31 32 36 20 36 32 | 20 36 30 20 39 37 20 39 |8 126 62| 60 97 9|
|00002340| 38 20 39 39 20 31 30 30 | 20 31 30 31 20 31 30 32 |8 99 100| 101 102|
|00002350| 20 31 30 33 20 31 30 34 | 20 31 30 35 20 31 30 36 | 103 104| 105 106|
|00002360| 20 31 30 37 20 31 30 38 | 20 31 30 39 20 31 31 30 | 107 108| 109 110|
|00002370| 20 31 31 31 20 31 31 32 | 20 31 31 33 20 31 31 34 | 111 112| 113 114|
|00002380| 20 31 31 35 20 31 31 36 | 20 31 31 37 20 31 31 38 | 115 116| 117 118|
|00002390| 20 31 31 39 20 31 32 30 | 20 31 32 31 20 31 32 32 | 119 120| 121 122|
|000023a0| 20 36 35 20 36 36 20 36 | 37 20 36 38 20 36 39 20 | 65 66 6|7 68 69 |
|000023b0| 37 30 20 37 31 20 37 32 | 20 37 33 20 37 34 20 37 |70 71 72| 73 74 7|
|000023c0| 35 20 37 36 20 37 37 20 | 37 38 20 37 39 20 38 30 |5 76 77 |78 79 80|
|000023d0| 20 38 31 20 38 32 20 38 | 33 20 38 34 20 38 35 20 | 81 82 8|3 84 85 |
|000023e0| 38 36 20 38 37 20 38 38 | 20 38 39 20 39 30 29 20 |86 87 88| 89 90) |
|000023f0| 28 77 68 69 74 65 73 70 | 61 63 65 20 33 32 20 39 |(whitesp|ace 32 9|
|00002400| 20 31 30 20 31 33 20 31 | 32 29 29 20 47 38 35 35 | 10 13 1|2)) G855|
|00002410| 31 37 20 6e 69 6c 20 65 | 6e 74 72 79 20 72 65 61 |17 nil e|ntry rea|
|00002420| 64 74 61 62 6c 65 20 47 | 38 35 35 32 31 20 63 68 |dtable G|85521 ch|
|00002430| 61 72 5d 20 35 29 20 22 | 5c 0a 54 68 65 20 6f 72 |ar] 5) "|\.The or|
|00002440| 69 67 69 6e 61 6c 20 28 | 43 4c 2d 6c 69 6b 65 29 |iginal (|CL-like)|
|00002450| 20 73 74 61 6e 64 61 72 | 64 20 72 65 61 64 74 61 | standar|d readta|
|00002460| 62 6c 65 2e 20 49 66 20 | 79 6f 75 20 65 76 65 72 |ble. If |you ever|
|00002470| 20 6d 6f 64 69 66 79 20 | 74 68 69 73 0a 72 65 61 | modify |this.rea|
|00002480| 64 74 61 62 6c 65 2c 20 | 79 6f 75 20 77 6f 6e 27 |dtable, |you won'|
|00002490| 74 20 62 65 20 61 62 6c | 65 20 74 6f 20 72 65 63 |t be abl|e to rec|
|000024a0| 6f 76 65 72 20 61 20 73 | 74 61 6e 64 61 72 64 20 |over a s|tandard |
|000024b0| 72 65 61 64 74 61 62 6c | 65 20 75 73 69 6e 67 0a |readtabl|e using.|
|000024c0| 28 63 6f 70 79 2d 72 65 | 61 64 74 61 62 6c 65 20 |(copy-re|adtable |
|000024d0| 6e 69 6c 29 22 29 0a 28 | 62 79 74 65 2d 63 6f 64 |nil)").(|byte-cod|
|000024e0| 65 20 22 c0 c1 c2 0b 23 | 88 c0 c4 c5 0b 23 88 c0 |e "....#|.....#..|
|000024f0| c6 c7 0b 23 88 c0 c8 c9 | 0b 23 88 c0 ca cb 0b 23 |...#....|.#.....#|
|00002500| 88 c0 cc cd 0b 23 88 c0 | ce cf 0b 23 88 c0 d0 d1 |.....#..|...#....|
|00002510| 0b 23 88 c0 d2 d3 0b 23 | 88 c0 d4 d5 0b 23 88 c0 |.#.....#|.....#..|
|00002520| d6 d7 0b 23 88 d8 d9 0b | 5c 22 88 da d9 d0 db 0b |...#....|\"......|
|00002530| 24 88 da d9 dc dd 0b 24 | 88 da d9 ca de 0b 24 88 |$......$|......$.|
|00002540| da d9 df e0 0b 24 88 da | d9 e1 e2 d9 df 0b 23 0b |.....$..|......#.|
|00002550| 24 88 da d9 e3 e4 0b 24 | 88 da d9 e5 e6 0b 24 88 |$......$|......$.|
|00002560| da d9 e7 e8 0b 24 88 da | d9 89 e9 0b 24 88 ea eb |.....$..|....$...|
|00002570| 4d 87 22 20 5b 73 65 74 | 2d 6d 61 63 72 6f 2d 63 |M." [set|-macro-c|
|00002580| 68 61 72 61 63 74 65 72 | 20 36 33 20 23 5b 28 73 |haracter| 63 #[(s|
|00002590| 74 72 65 61 6d 20 63 68 | 61 72 29 20 22 c0 75 88 |tream ch|ar) ".u.|
|000025a0| c1 5c 6e 21 87 22 20 5b | 2d 31 20 72 65 61 64 65 |.\n!." [|-1 reade|
|000025b0| 72 3a 6f 72 69 67 69 6e | 61 6c 2d 72 65 61 64 20 |r:origin|al-read |
|000025c0| 73 74 72 65 61 6d 5d 20 | 32 5d 20 72 65 61 64 65 |stream] |2] reade|
|000025d0| 72 3a 69 6e 74 65 72 6e | 61 6c 2d 73 74 61 6e 64 |r:intern|al-stand|
|000025e0| 61 72 64 2d 72 65 61 64 | 74 61 62 6c 65 20 33 34 |ard-read|table 34|
|000025f0| 20 23 5b 28 73 74 72 65 | 61 6d 20 63 68 61 72 29 | #[(stre|am char)|
|00002600| 20 22 c0 75 88 c1 5c 6e | 21 68 c3 55 ac 83 c0 75 | ".u..\n|!h.U...u|
|00002610| 88 87 22 20 5b 2d 31 20 | 72 65 61 64 65 72 3a 6f |.." [-1 |reader:o|
|00002620| 72 69 67 69 6e 61 6c 2d | 72 65 61 64 20 73 74 72 |riginal-|read str|
|00002630| 65 61 6d 20 33 34 5d 20 | 33 5d 20 34 30 20 23 5b |eam 34] |3] 40 #[|
|00002640| 28 73 74 72 65 61 6d 20 | 63 68 61 72 29 20 22 c0 |(stream |char) ".|
|00002650| c1 8d 87 22 20 5b 72 65 | 61 64 2d 6c 69 73 74 20 |..." [re|ad-list |
|00002660| 28 62 79 74 65 2d 63 6f | 64 65 20 22 c0 c1 1a 1b |(byte-co|de "....|
|00002670| c4 c5 8d 88 c6 0e 07 c8 | 5c 22 5c 6e 42 12 c4 13 |........|\"\nB...|
|00002680| c6 0e 07 c8 5c 22 88 c9 | ca 21 2a 87 22 20 5b 6c |....\"..|.!*." [l|
|00002690| 69 73 74 20 6e 69 6c 20 | 72 65 61 64 65 72 3a 73 |ist nil |reader:s|
|000026a0| 74 61 63 6b 20 72 65 61 | 64 65 72 3a 63 6f 6e 74 |tack rea|der:cont|
|000026b0| 65 78 74 20 64 6f 74 74 | 65 64 2d 70 61 69 72 20 |ext dott|ed-pair |
|000026c0| 28 62 79 74 65 2d 63 6f | 64 65 20 22 c0 09 c2 5c |(byte-co|de "...\|
|000026d0| 22 0b 42 13 aa 77 22 20 | 5b 72 65 61 64 65 72 3a |".B..w" |[reader:|
|000026e0| 72 65 61 64 2d 66 72 6f | 6d 2d 62 75 66 66 65 72 |read-fro|m-buffer|
|000026f0| 20 73 74 72 65 61 6d 20 | 74 20 72 65 61 64 65 72 | stream |t reader|
|00002700| 3a 73 74 61 63 6b 5d 20 | 33 29 20 72 65 61 64 65 |:stack] |3) reade|
|00002710| 72 3a 72 65 61 64 2d 66 | 72 6f 6d 2d 62 75 66 66 |r:read-f|rom-buff|
|00002720| 65 72 20 73 74 72 65 61 | 6d 20 74 20 65 72 72 6f |er strea|m t erro|
|00002730| 72 20 22 69 6c 6c 65 67 | 61 6c 20 64 6f 74 74 65 |r "illeg|al dotte|
|00002740| 64 20 70 61 69 72 20 72 | 65 61 64 20 73 79 6e 74 |d pair r|ead synt|
|00002750| 61 78 22 5d 20 33 29 5d | 20 32 5d 20 34 31 20 23 |ax"] 3)]| 2] 41 #|
|00002760| 5b 28 73 74 72 65 61 6d | 20 63 68 61 72 29 20 22 |[(stream| char) "|
|00002770| 08 c1 3d ab 86 c2 c3 0c | 9f 5c 22 87 08 c5 3d ab |..=.....|.\"...=.|
|00002780| 8a c2 c3 0c 41 9f 0c 40 | a4 5c 22 87 c6 c7 21 87 |....A..@|.\"...!.|
|00002790| 22 20 5b 72 65 61 64 65 | 72 3a 63 6f 6e 74 65 78 |" [reade|r:contex|
|000027a0| 74 20 6c 69 73 74 20 74 | 68 72 6f 77 20 72 65 61 |t list t|hrow rea|
|000027b0| 64 2d 6c 69 73 74 20 72 | 65 61 64 65 72 3a 73 74 |d-list r|eader:st|
|000027c0| 61 63 6b 20 64 6f 74 74 | 65 64 2d 70 61 69 72 20 |ack dott|ed-pair |
|000027d0| 65 72 72 6f 72 20 22 43 | 4c 20 72 65 61 64 20 65 |error "C|L read e|
|000027e0| 72 72 6f 72 3a 20 60 29 | 27 20 64 6f 65 73 6e 27 |rror: `)|' doesn'|
|000027f0| 74 20 65 6e 64 20 61 20 | 6c 69 73 74 22 5d 20 34 |t end a |list"] 4|
|00002800| 5d 20 34 36 20 23 5b 28 | 73 74 72 65 61 6d 20 63 |] 46 #[(|stream c|
|00002810| 68 61 72 29 20 22 08 c1 | 3d ab 84 c2 c3 21 88 c4 |har) "..|=....!..|
|00002820| c1 c5 5c 22 87 22 20 5b | 72 65 61 64 65 72 3a 63 |..\"." [|reader:c|
|00002830| 6f 6e 74 65 78 74 20 64 | 6f 74 74 65 64 2d 70 61 |ontext d|otted-pa|
|00002840| 69 72 20 65 72 72 6f 72 | 20 22 43 4c 20 72 65 61 |ir error| "CL rea|
|00002850| 64 20 65 72 72 6f 72 3a | 20 6e 6f 20 6d 6f 72 65 |d error:| no more|
|00002860| 20 74 68 61 6e 20 6f 6e | 65 20 60 2e 27 20 61 6c | than on|e `.' al|
|00002870| 6c 6f 77 65 64 20 69 6e | 20 6c 69 73 74 22 20 74 |lowed in| list" t|
|00002880| 68 72 6f 77 20 6e 69 6c | 5d 20 33 5d 20 39 31 20 |hrow nil|] 3] 91 |
|00002890| 23 5b 28 73 74 72 65 61 | 6d 20 63 68 61 72 29 20 |#[(strea|m char) |
|000028a0| 22 c0 19 c2 c3 8d 29 87 | 22 20 5b 76 65 63 74 6f |".....).|" [vecto|
|000028b0| 72 20 72 65 61 64 65 72 | 3a 63 6f 6e 74 65 78 74 |r reader|:context|
|000028c0| 20 72 65 61 64 2d 76 65 | 63 74 6f 72 20 28 62 79 | read-ve|ctor (by|
|000028d0| 74 65 2d 63 6f 64 65 20 | 22 c0 c1 1a 1b c4 0d c6 |te-code |".......|
|000028e0| 5c 22 5c 6e 42 12 aa 77 | 22 20 5b 76 65 63 74 6f |\"\nB..w|" [vecto|
|000028f0| 72 20 6e 69 6c 20 72 65 | 61 64 65 72 3a 73 74 61 |r nil re|ader:sta|
|00002900| 63 6b 20 72 65 61 64 65 | 72 3a 63 6f 6e 74 65 78 |ck reade|r:contex|
|00002910| 74 20 72 65 61 64 65 72 | 3a 72 65 61 64 2d 66 72 |t reader|:read-fr|
|00002920| 6f 6d 2d 62 75 66 66 65 | 72 20 73 74 72 65 61 6d |om-buffe|r stream|
|00002930| 20 74 5d 20 33 29 5d 20 | 32 5d 20 39 33 20 23 5b | t] 3)] |2] 93 #[|
|00002940| 28 73 74 72 65 61 6d 20 | 63 68 61 72 29 20 22 08 |(stream |char) ".|
|00002950| c1 3d ab 89 c2 c3 c4 c1 | 0d 9f 5c 22 5c 22 87 c6 |.=......|..\"\"..|
|00002960| c7 21 87 22 20 5b 72 65 | 61 64 65 72 3a 63 6f 6e |.!." [re|ader:con|
|00002970| 74 65 78 74 20 76 65 63 | 74 6f 72 20 74 68 72 6f |text vec|tor thro|
|00002980| 77 20 72 65 61 64 2d 76 | 65 63 74 6f 72 20 61 70 |w read-v|ector ap|
|00002990| 70 6c 79 20 72 65 61 64 | 65 72 3a 73 74 61 63 6b |ply read|er:stack|
|000029a0| 20 65 72 72 6f 72 20 22 | 43 4c 20 72 65 61 64 20 | error "|CL read |
|000029b0| 65 72 72 6f 72 3a 20 60 | 5d 27 20 64 6f 65 73 6e |error: `|]' doesn|
|000029c0| 27 74 20 65 6e 64 20 61 | 20 76 65 63 74 6f 72 22 |'t end a| vector"|
|000029d0| 5d 20 35 5d 20 33 39 20 | 23 5b 28 73 74 72 65 61 |] 5] 39 |#[(strea|
|000029e0| 6d 20 63 68 61 72 29 20 | 22 c0 c1 5c 6e c3 5c 22 |m char) |"..\n.\"|
|000029f0| 44 87 22 20 5b 71 75 6f | 74 65 20 72 65 61 64 65 |D." [quo|te reade|
|00002a00| 72 3a 72 65 61 64 2d 66 | 72 6f 6d 2d 62 75 66 66 |r:read-f|rom-buff|
|00002a10| 65 72 20 73 74 72 65 61 | 6d 20 74 5d 20 34 5d 20 |er strea|m t] 4] |
|00002a20| 39 36 20 23 5b 28 73 74 | 72 65 61 6d 20 63 68 61 |96 #[(st|ream cha|
|00002a30| 72 29 20 22 67 c0 55 ab | 82 c1 87 c1 c2 0b c4 5c |r) "g.U.|.......\|
|00002a40| 22 44 87 22 20 5b 33 32 | 20 5c 60 20 72 65 61 64 |"D." [32| \` read|
|00002a50| 65 72 3a 72 65 61 64 2d | 66 72 6f 6d 2d 62 75 66 |er:read-|from-buf|
|00002a60| 66 65 72 20 73 74 72 65 | 61 6d 20 74 5d 20 34 5d |fer stre|am t] 4]|
|00002a70| 20 34 34 20 23 5b 28 73 | 74 72 65 61 6d 20 63 68 | 44 #[(s|tream ch|
|00002a80| 61 72 29 20 22 67 c0 3d | ab 82 c1 87 67 c2 3d ab |ar) "g.=|....g.=.|
|00002a90| 92 c3 75 88 67 c0 3d ab | 82 c4 87 c4 c5 0e 06 c7 |..u.g.=.|........|
|00002aa0| 5c 22 44 87 c1 c5 0e 06 | c7 5c 22 44 87 22 20 5b |\"D.....|.\"D." [|
|00002ab0| 33 32 20 5c 2c 20 36 34 | 20 31 20 5c 2c 40 20 72 |32 \, 64| 1 \,@ r|
|00002ac0| 65 61 64 65 72 3a 72 65 | 61 64 2d 66 72 6f 6d 2d |eader:re|ad-from-|
|00002ad0| 62 75 66 66 65 72 20 73 | 74 72 65 61 6d 20 74 5d |buffer s|tream t]|
|00002ae0| 20 34 5d 20 35 39 20 23 | 5b 28 73 74 72 65 61 6d | 4] 59 #|[(stream|
|00002af0| 20 63 68 61 72 29 20 22 | c0 c1 77 88 c2 c3 c1 5c | char) "|..w....\|
|00002b00| 22 87 22 20 5b 22 5e 5c | 6e 0d 22 20 6e 69 6c 20 |"." ["^\|n." nil |
|00002b10| 74 68 72 6f 77 20 72 65 | 61 64 65 72 2d 69 67 6e |throw re|ader-ign|
|00002b20| 6f 72 65 5d 20 33 5d 20 | 6d 61 6b 65 2d 64 69 73 |ore] 3] |make-dis|
|00002b30| 70 61 74 63 68 2d 6d 61 | 63 72 6f 2d 63 68 61 72 |patch-ma|cro-char|
|00002b40| 61 63 74 65 72 20 33 35 | 20 73 65 74 2d 64 69 73 |acter 35| set-dis|
|00002b50| 70 61 74 63 68 2d 6d 61 | 63 72 6f 2d 63 68 61 72 |patch-ma|cro-char|
|00002b60| 61 63 74 65 72 20 23 5b | 28 73 74 72 65 61 6d 20 |acter #[|(stream |
|00002b70| 63 68 61 72 20 6e 29 20 | 22 08 c1 55 ac 85 c2 c3 |char n) |"..U....|
|00002b80| 08 5c 22 88 c4 c5 21 ab | 83 c6 aa 81 c7 c8 0e 09 |.\"...!.|........|
|00002b90| ca 5c 22 44 87 22 20 5b | 6e 20 30 20 65 72 72 6f |.\"D." [|n 0 erro|
|00002ba0| 72 20 22 43 6c 20 72 65 | 61 64 65 72 20 65 72 72 |r "Cl re|ader err|
|00002bb0| 6f 72 3a 20 6e 75 6d 65 | 72 69 63 20 69 6e 66 69 |or: nume|ric infi|
|00002bc0| 78 20 61 72 67 75 6d 65 | 6e 74 20 6e 6f 74 20 61 |x argume|nt not a|
|00002bd0| 6c 6c 6f 77 65 64 20 25 | 64 22 20 66 65 61 74 75 |llowed %|d" featu|
|00002be0| 72 65 70 20 63 6c 20 66 | 75 6e 63 74 69 6f 6e 2a |rep cl f|unction*|
|00002bf0| 20 66 75 6e 63 74 69 6f | 6e 20 72 65 61 64 65 72 | functio|n reader|
|00002c00| 3a 72 65 61 64 2d 66 72 | 6f 6d 2d 62 75 66 66 65 |:read-fr|om-buffe|
|00002c10| 72 20 73 74 72 65 61 6d | 20 74 5d 20 34 5d 20 39 |r stream| t] 4] 9|
|00002c20| 32 20 23 5b 28 73 74 72 | 65 61 6d 20 63 68 61 72 |2 #[(str|eam char|
|00002c30| 20 6e 29 20 22 08 c1 55 | ac 85 c2 c3 08 5c 22 88 | n) "..U|.....\".|
|00002c40| 67 c4 1d 1e 06 c7 0e 06 | 58 ab 86 0e 06 c8 58 ac |g.......|X.....X.|
|00002c50| 87 c9 75 88 0e 06 aa eb | ca 0e 0b cc 5c 22 89 16 |..u.....|....\"..|
|00002c60| 06 39 ab 87 cd 0e 06 21 | 15 aa 8a 0e 06 a8 ab 85 |.9.....!|........|
|00002c70| ce 0e 06 21 15 0d 47 c9 | 55 ab 85 cf 0d 21 aa c4 |...!..G.|U....!..|
|00002c80| 0e 06 d0 3d ab 83 d1 aa | bb 0e 06 d2 3d ab 83 d3 |...=....|....=...|
|00002c90| aa b2 0e 06 d4 3d ab 83 | d5 aa a9 0e 06 d6 3d ab |.....=..|......=.|
|00002ca0| 83 d7 aa a0 0e 06 d8 3d | ab 83 d9 aa 97 0e 06 da |.......=|........|
|00002cb0| 3d ab 83 db aa 8e 0e 06 | dc 3d ab 83 d3 aa 85 c2 |=.......|.=......|
|00002cc0| dd 0e 06 5c 22 2a 87 22 | 20 5b 6e 20 30 20 65 72 |...\"*."| [n 0 er|
|00002cd0| 72 6f 72 20 22 43 6c 20 | 72 65 61 64 65 72 20 65 |ror "Cl |reader e|
|00002ce0| 72 72 6f 72 3a 20 6e 75 | 6d 65 72 69 63 20 69 6e |rror: nu|meric in|
|00002cf0| 66 69 78 20 61 72 67 75 | 6d 65 6e 74 20 6e 6f 74 |fix argu|ment not|
|00002d00| 20 61 6c 6c 6f 77 65 64 | 20 25 64 22 20 6e 69 6c | allowed| %d" nil|
|00002d10| 20 6e 61 6d 65 20 6e 65 | 78 74 20 39 37 20 31 32 | name ne|xt 97 12|
|00002d20| 32 20 31 20 72 65 61 64 | 65 72 3a 72 65 61 64 2d |2 1 read|er:read-|
|00002d30| 66 72 6f 6d 2d 62 75 66 | 66 65 72 20 73 74 72 65 |from-buf|fer stre|
|00002d40| 61 6d 20 74 20 73 79 6d | 62 6f 6c 2d 6e 61 6d 65 |am t sym|bol-name|
|00002d50| 20 69 6e 74 2d 74 6f 2d | 73 74 72 69 6e 67 20 73 | int-to-|string s|
|00002d60| 74 72 69 6e 67 2d 74 6f | 2d 63 68 61 72 20 6c 69 |tring-to|-char li|
|00002d70| 6e 65 66 65 65 64 20 31 | 30 20 6e 65 77 6c 69 6e |nefeed 1|0 newlin|
|00002d80| 65 20 31 33 20 73 70 61 | 63 65 20 33 32 20 72 75 |e 13 spa|ce 32 ru|
|00002d90| 62 6f 75 74 20 38 20 70 | 61 67 65 20 31 32 20 74 |bout 8 p|age 12 t|
|00002da0| 61 62 20 39 20 72 65 74 | 75 72 6e 20 22 43 4c 20 |ab 9 ret|urn "CL |
|00002db0| 72 65 61 64 20 65 72 72 | 6f 72 3a 20 75 6e 6b 6e |read err|or: unkn|
|00002dc0| 6f 77 6e 20 63 68 61 72 | 61 63 74 65 72 20 73 70 |own char|acter sp|
|00002dd0| 65 63 69 66 69 63 61 74 | 69 6f 6e 20 60 25 73 27 |ecificat|ion `%s'|
|00002de0| 22 5d 20 34 5d 20 23 5b | 28 73 74 72 65 61 6d 20 |"] 4] #[|(stream |
|00002df0| 63 68 61 72 20 6e 29 20 | 22 08 c1 55 ac 85 c2 c3 |char n) |"..U....|
|00002e00| 08 5c 22 88 c4 c5 0e 06 | c7 5c 22 21 87 22 20 5b |.\".....|.\"!." [|
|00002e10| 6e 20 30 20 65 72 72 6f | 72 20 22 43 6c 20 72 65 |n 0 erro|r "Cl re|
|00002e20| 61 64 65 72 20 65 72 72 | 6f 72 3a 20 6e 75 6d 65 |ader err|or: nume|
|00002e30| 72 69 63 20 69 6e 66 69 | 78 20 61 72 67 75 6d 65 |ric infi|x argume|
|00002e40| 6e 74 20 6e 6f 74 20 61 | 6c 6c 6f 77 65 64 20 25 |nt not a|llowed %|
|00002e50| 64 22 20 65 76 61 6c 20 | 72 65 61 64 65 72 3a 72 |d" eval |reader:r|
|00002e60| 65 61 64 2d 66 72 6f 6d | 2d 62 75 66 66 65 72 20 |ead-from|-buffer |
|00002e70| 73 74 72 65 61 6d 20 74 | 5d 20 34 5d 20 38 30 20 |stream t|] 4] 80 |
|00002e80| 23 5b 28 73 74 72 65 61 | 6d 20 63 68 61 72 20 6e |#[(strea|m char n|
|00002e90| 29 20 22 08 c1 55 ac 85 | c2 c3 08 5c 22 88 c4 0d |) "..U..|...\"...|
|00002ea0| c6 5c 22 89 1e 07 3b ac | 86 c2 c8 0e 07 5c 22 88 |.\"...;.|.....\".|
|00002eb0| c9 0e 07 21 29 87 22 20 | 5b 6e 20 30 20 65 72 72 |...!)." |[n 0 err|
|00002ec0| 6f 72 20 22 43 6c 20 72 | 65 61 64 65 72 20 65 72 |or "Cl r|eader er|
|00002ed0| 72 6f 72 3a 20 6e 75 6d | 65 72 69 63 20 69 6e 66 |ror: num|eric inf|
|00002ee0| 69 78 20 61 72 67 75 6d | 65 6e 74 20 6e 6f 74 20 |ix argum|ent not |
|00002ef0| 61 6c 6c 6f 77 65 64 20 | 25 64 22 20 72 65 61 64 |allowed |%d" read|
|00002f00| 65 72 3a 72 65 61 64 2d | 66 72 6f 6d 2d 62 75 66 |er:read-|from-buf|
|00002f10| 66 65 72 20 73 74 72 65 | 61 6d 20 74 20 73 74 72 |fer stre|am t str|
|00002f20| 69 6e 67 20 22 43 6c 20 | 72 65 61 64 65 72 20 65 |ing "Cl |reader e|
|00002f30| 72 72 6f 72 3a 20 50 61 | 74 68 6e 61 6d 65 20 6d |rror: Pa|thname m|
|00002f40| 75 73 74 20 62 65 20 61 | 20 73 74 72 69 6e 67 3a |ust be a| string:|
|00002f50| 20 25 73 22 20 65 78 70 | 61 6e 64 2d 66 69 6c 65 | %s" exp|and-file|
|00002f60| 2d 6e 61 6d 65 5d 20 34 | 5d 20 31 31 32 20 67 65 |-name] 4|] 112 ge|
|00002f70| 74 2d 64 69 73 70 61 74 | 63 68 2d 6d 61 63 72 6f |t-dispat|ch-macro|
|00002f80| 2d 63 68 61 72 61 63 74 | 65 72 20 34 33 20 23 5b |-charact|er 43 #[|
|00002f90| 28 73 74 72 65 61 6d 20 | 63 68 61 72 20 6e 29 20 |(stream |char n) |
|00002fa0| 22 08 c1 55 ac 85 c2 c3 | 08 5c 22 88 c4 0d c6 5c |"..U....|.\"....\|
|00002fb0| 22 c4 0d c6 5c 22 1e 07 | 1e 08 c9 0e 08 21 ab 84 |"...\"..|.....!..|
|00002fc0| 0e 07 aa 84 ca cb cc 5c | 22 2a 87 22 20 5b 6e 20 |.......\|"*." [n |
|00002fd0| 30 20 65 72 72 6f 72 20 | 22 43 6c 20 72 65 61 64 |0 error |"Cl read|
|00002fe0| 65 72 20 65 72 72 6f 72 | 3a 20 6e 75 6d 65 72 69 |er error|: numeri|
|00002ff0| 63 20 69 6e 66 69 78 20 | 61 72 67 75 6d 65 6e 74 |c infix |argument|
|00003000| 20 6e 6f 74 20 61 6c 6c | 6f 77 65 64 20 25 64 22 | not all|owed %d"|
|00003010| 20 72 65 61 64 65 72 3a | 72 65 61 64 2d 66 72 6f | reader:|read-fro|
|00003020| 6d 2d 62 75 66 66 65 72 | 20 73 74 72 65 61 6d 20 |m-buffer| stream |
|00003030| 74 20 6f 62 6a 65 63 74 | 20 66 65 61 74 75 72 65 |t object| feature|
|00003040| 20 66 65 61 74 75 72 65 | 70 20 74 68 72 6f 77 20 | feature|p throw |
|00003050| 72 65 61 64 65 72 2d 69 | 67 6e 6f 72 65 20 6e 69 |reader-i|gnore ni|
|00003060| 6c 5d 20 34 5d 20 34 35 | 20 23 5b 28 73 74 72 65 |l] 4] 45| #[(stre|
|00003070| 61 6d 20 63 68 61 72 20 | 6e 29 20 22 08 c1 55 ac |am char |n) "..U.|
|00003080| 85 c2 c3 08 5c 22 88 c4 | 0d c6 5c 22 c4 0d c6 5c |....\"..|..\"...\|
|00003090| 22 1e 07 1e 08 c9 0e 08 | 21 ab 86 ca cb cc 5c 22 |".......|!.....\"|
|000030a0| aa 82 0e 07 2a 87 22 20 | 5b 6e 20 30 20 65 72 72 |....*." |[n 0 err|
|000030b0| 6f 72 20 22 43 6c 20 72 | 65 61 64 65 72 20 65 72 |or "Cl r|eader er|
|000030c0| 72 6f 72 3a 20 6e 75 6d | 65 72 69 63 20 69 6e 66 |ror: num|eric inf|
|000030d0| 69 78 20 61 72 67 75 6d | 65 6e 74 20 6e 6f 74 20 |ix argum|ent not |
|000030e0| 61 6c 6c 6f 77 65 64 20 | 25 64 22 20 72 65 61 64 |allowed |%d" read|
|000030f0| 65 72 3a 72 65 61 64 2d | 66 72 6f 6d 2d 62 75 66 |er:read-|from-buf|
|00003100| 66 65 72 20 73 74 72 65 | 61 6d 20 74 20 6f 62 6a |fer stre|am t obj|
|00003110| 65 63 74 20 66 65 61 74 | 75 72 65 20 66 65 61 74 |ect feat|ure feat|
|00003120| 75 72 65 70 20 74 68 72 | 6f 77 20 72 65 61 64 65 |urep thr|ow reade|
|00003130| 72 2d 69 67 6e 6f 72 65 | 20 6e 69 6c 5d 20 34 5d |r-ignore| nil] 4]|
|00003140| 20 36 31 20 23 5b 28 73 | 74 72 65 61 6d 20 63 68 | 61 #[(s|tream ch|
|00003150| 61 72 20 6e 29 20 22 08 | 09 3e ab 86 c2 c3 21 88 |ar n) ".|.>....!.|
|00003160| aa 84 08 09 42 11 c4 08 | 21 1d c6 0d 0e 07 c8 c9 |....B...|!.......|
|00003170| 24 ae 8a ca 0d 21 0e 07 | 42 89 16 07 40 89 1e 0b |$....!..|B...@...|
|00003180| cc 0e 0d ce 5c 22 4c 2a | 87 22 20 5b 6e 20 72 65 |....\"L*|." [n re|
|00003190| 61 64 65 72 3a 73 68 61 | 72 65 64 2d 73 74 72 75 |ader:sha|red-stru|
|000031a0| 63 74 75 72 65 2d 6c 61 | 62 65 6c 73 20 65 72 72 |cture-la|bels err|
|000031b0| 6f 72 20 22 43 6c 20 72 | 65 61 64 65 72 20 65 72 |or "Cl r|eader er|
|000031c0| 72 6f 72 3a 20 6c 61 62 | 65 6c 20 64 65 66 69 6e |ror: lab|el defin|
|000031d0| 65 64 20 74 77 69 63 65 | 22 20 69 6e 74 2d 74 6f |ed twice|" int-to|
|000031e0| 2d 73 74 72 69 6e 67 20 | 73 74 72 69 6e 67 20 66 |-string |string f|
|000031f0| 69 6e 64 20 72 65 61 64 | 65 72 3a 73 68 61 72 65 |ind read|er:share|
|00003200| 64 2d 73 74 72 75 63 74 | 75 72 65 2d 72 65 66 65 |d-struct|ure-refe|
|00003210| 72 65 6e 63 65 73 20 3a | 74 65 73 74 20 73 74 72 |rences :|test str|
|00003220| 69 6e 67 3d 20 6d 61 6b | 65 2d 73 79 6d 62 6f 6c |ing= mak|e-symbol|
|00003230| 20 72 65 66 20 72 65 61 | 64 65 72 3a 72 65 61 64 | ref rea|der:read|
|00003240| 2d 66 72 6f 6d 2d 62 75 | 66 66 65 72 20 73 74 72 |-from-bu|ffer str|
|00003250| 65 61 6d 20 74 5d 20 36 | 5d 20 23 5b 28 73 74 72 |eam t] 6|] #[(str|
|00003260| 65 61 6d 20 63 68 61 72 | 20 6e 29 20 22 08 ac 84 |eam char| n) "...|
|00003270| c1 c2 21 88 c3 0c 21 1d | c6 0d 0e 07 c8 c9 24 ae |..!...!.|......$.|
|00003280| 8a ca 0d 21 0e 07 42 89 | 16 07 40 29 87 22 20 5b |...!..B.|..@)." [|
|00003290| 72 65 63 75 72 73 69 76 | 65 2d 70 20 65 72 72 6f |recursiv|e-p erro|
|000032a0| 72 20 22 43 6c 20 72 65 | 61 64 65 72 20 65 72 72 |r "Cl re|ader err|
|000032b0| 6f 72 3a 20 72 65 66 65 | 72 65 6e 63 65 73 20 61 |or: refe|rences a|
|000032c0| 74 20 74 6f 70 20 6c 65 | 76 65 6c 20 6e 6f 74 20 |t top le|vel not |
|000032d0| 61 6c 6c 6f 77 65 64 22 | 20 69 6e 74 2d 74 6f 2d |allowed"| int-to-|
|000032e0| 73 74 72 69 6e 67 20 6e | 20 73 74 72 69 6e 67 20 |string n| string |
|000032f0| 66 69 6e 64 20 72 65 61 | 64 65 72 3a 73 68 61 72 |find rea|der:shar|
|00003300| 65 64 2d 73 74 72 75 63 | 74 75 72 65 2d 72 65 66 |ed-struc|ture-ref|
|00003310| 65 72 65 6e 63 65 73 20 | 3a 74 65 73 74 20 73 74 |erences |:test st|
|00003320| 72 69 6e 67 3d 20 6d 61 | 6b 65 2d 73 79 6d 62 6f |ring= ma|ke-symbo|
|00003330| 6c 5d 20 36 5d 20 72 65 | 61 64 65 72 3a 72 65 73 |l] 6] re|ader:res|
|00003340| 74 6f 72 65 2d 73 68 61 | 72 65 64 2d 73 74 72 75 |tore-sha|red-stru|
|00003350| 63 74 75 72 65 20 23 5b | 28 6f 62 6a 29 20 22 08 |cture #[|(obj) ".|
|00003360| 3a ab a8 08 40 09 3e ab | 88 08 89 40 4a a0 88 aa |:...@.>.|...@J...|
|00003370| 85 c2 08 40 21 88 08 41 | 09 3e ab 88 08 89 41 4a |...@!..A|.>....AJ|
|00003380| a1 88 aa b7 c2 08 41 21 | 88 aa b0 c3 08 21 ab ab |......A!|.....!..|
|00003390| c4 1d 08 47 1e 06 0d 0e | 06 57 ab 9e 08 0d 48 09 |...G....|.W....H.|
|000033a0| 3e ab 8a 08 0d 08 0d 48 | 4a 49 88 aa 86 c2 08 0d |>......H|JI......|
|000033b0| 48 21 88 0d c7 5c 5c 89 | 15 aa 5d 2a 08 87 22 20 |H!...\\.|..]*.." |
|000033c0| 5b 6f 62 6a 20 72 65 61 | 64 65 72 3a 73 68 61 72 |[obj rea|der:shar|
|000033d0| 65 64 2d 73 74 72 75 63 | 74 75 72 65 2d 72 65 66 |ed-struc|ture-ref|
|000033e0| 65 72 65 6e 63 65 73 20 | 72 65 61 64 65 72 3a 72 |erences |reader:r|
|000033f0| 65 73 74 6f 72 65 2d 73 | 68 61 72 65 64 2d 73 74 |estore-s|hared-st|
|00003400| 72 75 63 74 75 72 65 20 | 76 65 63 74 6f 72 70 20 |ructure |vectorp |
|00003410| 30 20 69 20 47 38 35 35 | 33 31 20 31 5d 20 35 5d |0 i G855|31 1] 5]|
|00003420| 5d 20 37 29 0a 28 64 65 | 66 76 61 72 20 2a 72 65 |] 7).(de|fvar *re|
|00003430| 61 64 74 61 62 6c 65 2a | 20 28 63 6f 70 79 2d 72 |adtable*| (copy-r|
|00003440| 65 61 64 74 61 62 6c 65 | 20 6e 69 6c 29 20 22 5c |eadtable| nil) "\|
|00003450| 0a 54 68 65 20 63 75 72 | 72 65 6e 74 20 72 65 61 |.The cur|rent rea|
|00003460| 64 74 61 62 6c 65 2e 22 | 29 0a 28 62 79 74 65 2d |dtable."|).(byte-|
|00003470| 63 6f 64 65 20 22 c0 c1 | 21 ac 85 c1 c2 4b 4d 88 |code "..|!....KM.|
|00003480| c0 87 22 20 5b 66 62 6f | 75 6e 64 70 20 72 65 61 |.." [fbo|undp rea|
|00003490| 64 65 72 3a 6f 72 69 67 | 69 6e 61 6c 2d 65 76 61 |der:orig|inal-eva|
|000034a0| 6c 2d 63 75 72 72 65 6e | 74 2d 62 75 66 66 65 72 |l-curren|t-buffer|
|000034b0| 20 65 76 61 6c 2d 63 75 | 72 72 65 6e 74 2d 62 75 | eval-cu|rrent-bu|
|000034c0| 66 66 65 72 5d 20 32 29 | 0a 28 66 73 65 74 20 27 |ffer] 2)|.(fset '|
|000034d0| 72 65 61 64 65 72 3a 65 | 76 61 6c 2d 63 75 72 72 |reader:e|val-curr|
|000034e0| 65 6e 74 2d 62 75 66 66 | 65 72 20 23 5b 28 26 6f |ent-buff|er #[(&o|
|000034f0| 70 74 69 6f 6e 61 6c 20 | 70 72 69 6e 74 66 6c 61 |ptional |printfla|
|00003500| 67 29 20 22 08 ac 84 c1 | 5c 6e 21 87 c3 70 21 87 |g) "....|\n!..p!.|
|00003510| 22 20 5b 63 6c 2d 72 65 | 61 64 2d 61 63 74 69 76 |" [cl-re|ad-activ|
|00003520| 65 20 72 65 61 64 65 72 | 3a 6f 72 69 67 69 6e 61 |e reader|:origina|
|00003530| 6c 2d 65 76 61 6c 2d 63 | 75 72 72 65 6e 74 2d 62 |l-eval-c|urrent-b|
|00003540| 75 66 66 65 72 20 70 72 | 69 6e 74 66 6c 61 67 20 |uffer pr|intflag |
|00003550| 72 65 61 64 65 72 3a 65 | 76 61 6c 2d 62 75 66 66 |reader:e|val-buff|
|00003560| 65 72 5d 20 32 20 22 5c | 0a 45 76 61 6c 75 61 74 |er] 2 "\|.Evaluat|
|00003570| 65 20 74 68 65 20 63 75 | 72 72 65 6e 74 20 62 75 |e the cu|rrent bu|
|00003580| 66 66 65 72 20 61 73 20 | 4c 69 73 70 20 63 6f 64 |ffer as |Lisp cod|
|00003590| 65 2e 0a 50 72 6f 67 72 | 61 6d 73 20 63 61 6e 20 |e..Progr|ams can |
|000035a0| 70 61 73 73 20 61 72 67 | 75 6d 65 6e 74 20 50 52 |pass arg|ument PR|
|000035b0| 49 4e 54 46 4c 41 47 20 | 77 68 69 63 68 20 63 6f |INTFLAG |which co|
|000035c0| 6e 74 72 6f 6c 73 20 70 | 72 69 6e 74 69 6e 67 20 |ntrols p|rinting |
|000035d0| 6f 66 20 6f 75 74 70 75 | 74 3a 0a 6e 69 6c 20 6d |of outpu|t:.nil m|
|000035e0| 65 61 6e 73 20 64 69 73 | 63 61 72 64 20 69 74 3b |eans dis|card it;|
|000035f0| 20 61 6e 79 74 68 69 6e | 67 20 65 6c 73 65 20 69 | anythin|g else i|
|00003600| 73 20 73 74 72 65 61 6d | 20 66 6f 72 20 70 72 69 |s stream| for pri|
|00003610| 6e 74 2e 0a 0a 54 68 69 | 73 20 69 73 20 74 68 65 |nt...Thi|s is the|
|00003620| 20 63 6c 2d 72 65 61 64 | 20 72 65 70 6c 61 63 65 | cl-read| replace|
|00003630| 6d 65 6e 74 20 6f 66 20 | 74 68 65 20 73 74 61 6e |ment of |the stan|
|00003640| 64 61 72 64 20 65 6c 69 | 73 70 20 66 75 6e 63 74 |dard eli|sp funct|
|00003650| 69 6f 6e 0a 60 65 76 61 | 6c 2d 63 75 72 72 65 6e |ion.`eva|l-curren|
|00003660| 74 2d 62 75 66 66 65 72 | 27 2e 22 20 6e 69 6c 5d |t-buffer|'." nil]|
|00003670| 29 0a 28 62 79 74 65 2d | 63 6f 64 65 20 22 c0 c1 |).(byte-|code "..|
|00003680| 21 ac 8d c1 c0 c2 21 ab | 84 c2 4b aa 81 c2 4d 88 |!.....!.|..K...M.|
|00003690| c0 87 22 20 5b 66 62 6f | 75 6e 64 70 20 72 65 61 |.." [fbo|undp rea|
|000036a0| 64 65 72 3a 6f 72 69 67 | 69 6e 61 6c 2d 65 76 61 |der:orig|inal-eva|
|000036b0| 6c 2d 62 75 66 66 65 72 | 20 65 76 61 6c 2d 62 75 |l-buffer| eval-bu|
|000036c0| 66 66 65 72 5d 20 33 29 | 0a 28 66 73 65 74 20 27 |ffer] 3)|.(fset '|
|000036d0| 72 65 61 64 65 72 3a 65 | 76 61 6c 2d 62 75 66 66 |reader:e|val-buff|
|000036e0| 65 72 20 23 5b 28 62 75 | 66 6e 61 6d 65 20 26 6f |er #[(bu|fname &o|
|000036f0| 70 74 69 6f 6e 61 6c 20 | 70 72 69 6e 74 66 6c 61 |ptional |printfla|
|00003700| 67 29 20 22 08 ac 85 c1 | 5c 6e 0b 5c 22 87 8a c4 |g) "....|\n.\"...|
|00003710| 5c 6e 21 ae 84 c5 c6 5c | 6e 5c 22 71 88 c7 65 64 |\n!....\|n\"q..ed|
|00003720| 0b 23 29 87 22 20 5b 63 | 6c 2d 72 65 61 64 2d 61 |.#)." [c|l-read-a|
|00003730| 63 74 69 76 65 20 72 65 | 61 64 65 72 3a 6f 72 69 |ctive re|ader:ori|
|00003740| 67 69 6e 61 6c 2d 65 76 | 61 6c 2d 62 75 66 66 65 |ginal-ev|al-buffe|
|00003750| 72 20 62 75 66 6e 61 6d | 65 20 70 72 69 6e 74 66 |r bufnam|e printf|
|00003760| 6c 61 67 20 67 65 74 2d | 62 75 66 66 65 72 20 65 |lag get-|buffer e|
|00003770| 72 72 6f 72 20 22 4e 6f | 20 73 75 63 68 20 62 75 |rror "No| such bu|
|00003780| 66 66 65 72 3a 20 25 73 | 22 20 72 65 61 64 65 72 |ffer: %s|" reader|
|00003790| 3a 65 76 61 6c 2d 72 65 | 67 69 6f 6e 5d 20 34 20 |:eval-re|gion] 4 |
|000037a0| 22 5c 0a 45 78 65 63 75 | 74 65 20 42 55 46 46 45 |"\.Execu|te BUFFE|
|000037b0| 52 20 61 73 20 4c 69 73 | 70 20 63 6f 64 65 2e 20 |R as Lis|p code. |
|000037c0| 20 50 72 6f 67 72 61 6d | 73 20 63 61 6e 20 70 61 | Program|s can pa|
|000037d0| 73 73 20 61 72 67 75 6d | 65 6e 74 20 50 52 49 4e |ss argum|ent PRIN|
|000037e0| 54 46 4c 41 47 0a 77 68 | 69 63 68 20 63 6f 6e 74 |TFLAG.wh|ich cont|
|000037f0| 72 6f 6c 73 20 70 72 69 | 6e 74 69 6e 67 20 6f 66 |rols pri|nting of|
|00003800| 20 6f 75 74 70 75 74 3a | 20 6e 69 6c 20 6d 65 61 | output:| nil mea|
|00003810| 6e 73 20 64 69 73 63 61 | 72 64 20 69 74 3b 20 61 |ns disca|rd it; a|
|00003820| 6e 79 74 68 69 6e 67 20 | 65 6c 73 65 0a 69 73 20 |nything |else.is |
|00003830| 73 74 72 65 61 6d 20 66 | 6f 72 20 70 72 69 6e 74 |stream f|or print|
|00003840| 2e 0a 0a 54 68 69 73 20 | 69 73 20 74 68 65 20 63 |...This |is the c|
|00003850| 6c 2d 72 65 61 64 20 72 | 65 70 6c 61 63 65 6d 65 |l-read r|eplaceme|
|00003860| 6e 74 20 6f 66 20 74 68 | 65 20 73 74 61 6e 64 61 |nt of th|e standa|
|00003870| 72 64 20 65 6c 69 73 70 | 20 66 75 6e 63 74 69 6f |rd elisp| functio|
|00003880| 6e 0a 60 65 76 61 6c 2d | 62 75 66 66 65 72 27 2e |n.`eval-|buffer'.|
|00003890| 22 20 22 62 42 75 66 66 | 65 72 3a 20 22 5d 29 0a |" "bBuff|er: "]).|
|000038a0| 28 62 79 74 65 2d 63 6f | 64 65 20 22 c0 c1 21 ac |(byte-co|de "..!.|
|000038b0| 85 c1 c2 4b 4d 88 c0 87 | 22 20 5b 66 62 6f 75 6e |...KM...|" [fboun|
|000038c0| 64 70 20 72 65 61 64 65 | 72 3a 6f 72 69 67 69 6e |dp reade|r:origin|
|000038d0| 61 6c 2d 65 76 61 6c 2d | 72 65 67 69 6f 6e 20 65 |al-eval-|region e|
|000038e0| 76 61 6c 2d 72 65 67 69 | 6f 6e 5d 20 32 29 0a 28 |val-regi|on] 2).(|
|000038f0| 66 73 65 74 20 27 72 65 | 61 64 65 72 3a 65 76 61 |fset 're|ader:eva|
|00003900| 6c 2d 72 65 67 69 6f 6e | 20 23 5b 28 73 74 61 72 |l-region| #[(star|
|00003910| 74 20 65 6e 64 20 26 6f | 70 74 69 6f 6e 61 6c 20 |t end &o|ptional |
|00003920| 6f 75 74 70 75 74 29 20 | 22 08 ac 86 c1 5c 6e 0b |output) |"....\n.|
|00003930| 0c 23 87 60 70 70 c5 20 | 0b c6 93 c6 89 1e 07 1e |.#.`pp. |........|
|00003940| 08 1e 09 1e 5c 6e 1e 0b | 1e 0c 5c 6e 62 88 cd 20 |....\n..|..\nb.. |
|00003950| 88 60 0e 09 57 ab d3 ce | 0e 5c 6e 21 16 08 70 1e |.`..W...|.\n!..p.|
|00003960| 0f 0e 5c 6e 71 88 d0 0e | 08 21 16 07 70 16 5c 6e |..\nq...|.!..p.\n|
|00003970| 0e 0f 71 88 29 0c ab a8 | 0c ae 81 d1 1e 12 0e 07 |..q.)...|........|
|00003980| 0e 13 42 16 13 0e 12 d1 | 3d ab 87 d4 0e 07 21 88 |..B.....|=.....!.|
|00003990| aa 8d d5 d6 21 88 d4 0e | 07 21 88 d5 d6 21 88 29 |....!...|.!...!.)|
|000039a0| 0e 09 60 5d cd 20 88 60 | 5e 62 88 aa 27 0c ac 88 |..`]. .`|^b..'...|
|000039b0| 0e 0b 71 88 0e 0c 62 88 | 2e 06 c6 87 22 20 5b 63 |..q...b.|...." [c|
|000039c0| 6c 2d 72 65 61 64 2d 61 | 63 74 69 76 65 20 72 65 |l-read-a|ctive re|
|000039d0| 61 64 65 72 3a 6f 72 69 | 67 69 6e 61 6c 2d 65 76 |ader:ori|ginal-ev|
|000039e0| 61 6c 2d 72 65 67 69 6f | 6e 20 73 74 61 72 74 20 |al-regio|n start |
|000039f0| 65 6e 64 20 6f 75 74 70 | 75 74 20 6d 61 6b 65 2d |end outp|ut make-|
|00003a00| 6d 61 72 6b 65 72 20 6e | 69 6c 20 76 61 6c 20 66 |marker n|il val f|
|00003a10| 6f 72 6d 20 65 6e 64 2d | 6d 61 72 6b 65 72 20 69 |orm end-|marker i|
|00003a20| 6e 73 69 64 65 2d 62 75 | 66 20 62 75 66 20 70 6e |nside-bu|f buf pn|
|00003a30| 74 20 72 65 61 64 65 72 | 3a 73 6b 69 70 2d 77 68 |t reader|:skip-wh|
|00003a40| 69 74 65 73 70 61 63 65 | 20 72 65 61 64 65 72 3a |itespace| reader:|
|00003a50| 72 65 61 64 2d 66 72 6f | 6d 2d 62 75 66 66 65 72 |read-fro|m-buffer|
|00003a60| 20 63 75 72 72 65 6e 74 | 2d 62 75 66 66 65 72 20 | current|-buffer |
|00003a70| 65 76 61 6c 20 74 20 73 | 74 61 6e 64 61 72 64 2d |eval t s|tandard-|
|00003a80| 6f 75 74 70 75 74 20 76 | 61 6c 75 65 73 20 70 72 |output v|alues pr|
|00003a90| 69 6e 31 20 70 72 69 6e | 63 20 22 5c 6e 22 5d 20 |in1 prin|c "\n"] |
|00003aa0| 36 20 22 5c 0a 45 78 65 | 63 75 74 65 20 74 68 65 |6 "\.Exe|cute the|
|00003ab0| 20 72 65 67 69 6f 6e 20 | 61 73 20 4c 69 73 70 20 | region |as Lisp |
|00003ac0| 63 6f 64 65 2e 0a 57 68 | 65 6e 20 63 61 6c 6c 65 |code..Wh|en calle|
|00003ad0| 64 20 66 72 6f 6d 20 70 | 72 6f 67 72 61 6d 73 2c |d from p|rograms,|
|00003ae0| 20 65 78 70 65 63 74 73 | 20 74 77 6f 20 61 72 67 | expects| two arg|
|00003af0| 75 6d 65 6e 74 73 2c 0a | 67 69 76 69 6e 67 20 73 |uments,.|giving s|
|00003b00| 74 61 72 74 69 6e 67 20 | 61 6e 64 20 65 6e 64 69 |tarting |and endi|
|00003b10| 6e 67 20 69 6e 64 69 63 | 65 73 20 69 6e 20 74 68 |ng indic|es in th|
|00003b20| 65 20 63 75 72 72 65 6e | 74 20 62 75 66 66 65 72 |e curren|t buffer|
|00003b30| 0a 6f 66 20 74 68 65 20 | 74 65 78 74 20 74 6f 20 |.of the |text to |
|00003b40| 62 65 20 65 78 65 63 75 | 74 65 64 2e 0a 50 72 6f |be execu|ted..Pro|
|00003b50| 67 72 61 6d 73 20 63 61 | 6e 20 70 61 73 73 20 74 |grams ca|n pass t|
|00003b60| 68 69 72 64 20 61 72 67 | 75 6d 65 6e 74 20 50 52 |hird arg|ument PR|
|00003b70| 49 4e 54 46 4c 41 47 20 | 77 68 69 63 68 20 63 6f |INTFLAG |which co|
|00003b80| 6e 74 72 6f 6c 73 20 6f | 75 74 70 75 74 3a 0a 6e |ntrols o|utput:.n|
|00003b90| 69 6c 20 6d 65 61 6e 73 | 20 64 69 73 63 61 72 64 |il means| discard|
|00003ba0| 20 69 74 3b 20 61 6e 79 | 74 68 69 6e 67 20 65 6c | it; any|thing el|
|00003bb0| 73 65 20 69 73 20 73 74 | 72 65 61 6d 20 66 6f 72 |se is st|ream for|
|00003bc0| 20 70 72 69 6e 74 69 6e | 67 20 69 74 2e 0a 0a 49 | printin|g it...I|
|00003bd0| 66 20 74 68 65 72 65 20 | 69 73 20 6e 6f 20 65 72 |f there |is no er|
|00003be0| 72 6f 72 2c 20 70 6f 69 | 6e 74 20 64 6f 65 73 20 |ror, poi|nt does |
|00003bf0| 6e 6f 74 20 6d 6f 76 65 | 2e 20 20 49 66 20 74 68 |not move|. If th|
|00003c00| 65 72 65 20 69 73 20 61 | 6e 20 65 72 72 6f 72 2c |ere is a|n error,|
|00003c10| 0a 70 6f 69 6e 74 20 72 | 65 6d 61 69 6e 73 20 61 |.point r|emains a|
|00003c20| 74 20 74 68 65 20 65 6e | 64 20 6f 66 20 74 68 65 |t the en|d of the|
|00003c30| 20 6c 61 73 74 20 63 68 | 61 72 61 63 74 65 72 20 | last ch|aracter |
|00003c40| 72 65 61 64 20 66 72 6f | 6d 20 74 68 65 20 62 75 |read fro|m the bu|
|00003c50| 66 66 65 72 2e 0a 0a 61 | 72 67 75 6d 65 6e 74 73 |ffer...a|rguments|
|00003c60| 3a 20 28 62 20 65 20 26 | 6f 70 74 69 6f 6e 61 6c |: (b e &|optional|
|00003c70| 20 70 72 69 6e 74 66 6c | 61 67 29 0a 0a 54 68 69 | printfl|ag)..Thi|
|00003c80| 73 20 69 73 20 74 68 65 | 20 63 6c 2d 72 65 61 64 |s is the| cl-read|
|00003c90| 20 72 65 70 6c 61 63 65 | 6d 65 6e 74 20 6f 66 20 | replace|ment of |
|00003ca0| 74 68 65 20 73 74 61 6e | 64 61 72 64 20 65 6c 69 |the stan|dard eli|
|00003cb0| 73 70 20 66 75 6e 63 74 | 69 6f 6e 0a 60 65 76 61 |sp funct|ion.`eva|
|00003cc0| 6c 2d 72 65 67 69 6f 6e | 27 2e 22 20 22 72 22 5d |l-region|'." "r"]|
|00003cd0| 29 0a 28 62 79 74 65 2d | 63 6f 64 65 20 22 c0 c1 |).(byte-|code "..|
|00003ce0| 4d 88 c2 c3 4d 88 c4 c5 | 4d 88 c2 20 87 22 20 5b |M...M...|M.. ." [|
|00003cf0| 72 65 61 64 65 72 3a 73 | 6b 69 70 2d 77 68 69 74 |reader:s|kip-whit|
|00003d00| 65 73 70 61 63 65 20 23 | 5b 6e 69 6c 20 22 c0 c1 |espace #|[nil "..|
|00003d10| 77 88 67 c2 55 ad 8a c3 | c1 77 88 c0 c1 77 88 aa |w.g.U...|.w...w..|
|00003d20| 71 87 22 20 5b 22 20 09 | 0d 5c 6e 0c 22 20 6e 69 |q." [" .|.\n." ni|
|00003d30| 6c 20 35 39 20 22 5e 5c | 6e 0d 22 5d 20 32 5d 20 |l 59 "^\|n."] 2] |
|00003d40| 63 6c 2d 72 65 61 64 65 | 72 2d 69 6e 73 74 61 6c |cl-reade|r-instal|
|00003d50| 6c 20 23 5b 6e 69 6c 20 | 22 c0 c1 4d 88 c2 c3 4d |l #[nil |"..M...M|
|00003d60| 88 c4 c5 4d 88 c6 c7 4d | 88 c8 c9 4d 87 22 20 5b |...M...M|...M." [|
|00003d70| 72 65 61 64 20 72 65 61 | 64 65 72 3a 72 65 61 64 |read rea|der:read|
|00003d80| 20 72 65 61 64 2d 66 72 | 6f 6d 2d 73 74 72 69 6e | read-fr|om-strin|
|00003d90| 67 20 72 65 61 64 65 72 | 3a 72 65 61 64 2d 66 72 |g reader|:read-fr|
|00003da0| 6f 6d 2d 73 74 72 69 6e | 67 20 65 76 61 6c 2d 63 |om-strin|g eval-c|
|00003db0| 75 72 72 65 6e 74 2d 62 | 75 66 66 65 72 20 72 65 |urrent-b|uffer re|
|00003dc0| 61 64 65 72 3a 65 76 61 | 6c 2d 63 75 72 72 65 6e |ader:eva|l-curren|
|00003dd0| 74 2d 62 75 66 66 65 72 | 20 65 76 61 6c 2d 62 75 |t-buffer| eval-bu|
|00003de0| 66 66 65 72 20 72 65 61 | 64 65 72 3a 65 76 61 6c |ffer rea|der:eval|
|00003df0| 2d 62 75 66 66 65 72 20 | 65 76 61 6c 2d 72 65 67 |-buffer |eval-reg|
|00003e00| 69 6f 6e 20 72 65 61 64 | 65 72 3a 65 76 61 6c 2d |ion read|er:eval-|
|00003e10| 72 65 67 69 6f 6e 5d 20 | 32 20 6e 69 6c 20 6e 69 |region] |2 nil ni|
|00003e20| 6c 5d 20 63 6c 2d 72 65 | 61 64 65 72 2d 75 6e 69 |l] cl-re|ader-uni|
|00003e30| 6e 73 74 61 6c 6c 20 23 | 5b 6e 69 6c 20 22 c0 c1 |nstall #|[nil "..|
|00003e40| 4b 4d 88 c2 c3 4b 4d 88 | c4 c5 4b 4d 88 c6 c7 4b |KM...KM.|..KM...K|
|00003e50| 4d 88 c8 c9 4b 4d 87 22 | 20 5b 72 65 61 64 20 72 |M...KM."| [read r|
|00003e60| 65 61 64 65 72 3a 6f 72 | 69 67 69 6e 61 6c 2d 72 |eader:or|iginal-r|
|00003e70| 65 61 64 20 72 65 61 64 | 2d 66 72 6f 6d 2d 73 74 |ead read|-from-st|
|00003e80| 72 69 6e 67 20 72 65 61 | 64 65 72 3a 6f 72 69 67 |ring rea|der:orig|
|00003e90| 69 6e 61 6c 2d 72 65 61 | 64 2d 66 72 6f 6d 2d 73 |inal-rea|d-from-s|
|00003ea0| 74 72 69 6e 67 20 65 76 | 61 6c 2d 63 75 72 72 65 |tring ev|al-curre|
|00003eb0| 6e 74 2d 62 75 66 66 65 | 72 20 72 65 61 64 65 72 |nt-buffe|r reader|
|00003ec0| 3a 6f 72 69 67 69 6e 61 | 6c 2d 65 76 61 6c 2d 63 |:origina|l-eval-c|
|00003ed0| 75 72 72 65 6e 74 2d 62 | 75 66 66 65 72 20 65 76 |urrent-b|uffer ev|
|00003ee0| 61 6c 2d 62 75 66 66 65 | 72 20 72 65 61 64 65 72 |al-buffe|r reader|
|00003ef0| 3a 6f 72 69 67 69 6e 61 | 6c 2d 65 76 61 6c 2d 62 |:origina|l-eval-b|
|00003f00| 75 66 66 65 72 20 65 76 | 61 6c 2d 72 65 67 69 6f |uffer ev|al-regio|
|00003f10| 6e 20 72 65 61 64 65 72 | 3a 6f 72 69 67 69 6e 61 |n reader|:origina|
|00003f20| 6c 2d 65 76 61 6c 2d 72 | 65 67 69 6f 6e 5d 20 32 |l-eval-r|egion] 2|
|00003f30| 20 6e 69 6c 20 6e 69 6c | 5d 5d 20 32 29 0a | nil nil|]] 2). |
+--------+-------------------------+-------------------------+--------+--------+